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supporto magnetico. Per scaricarlo visitare il sito della rivista. 
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Signori: si cambia! 

Era il gennaio 2006 quando usciva timidamente il numero 
uno della nostra rivista. Da allora una corsa ininterrotta 
di ventisei numeri che hanno impegnato non poco, come 
potete ben immaginare, il nostro gruppo redazionale e 
qualche amico che ci ha aiutato nel corso della nostra 

storia. 

Come regola interna ci siamo dati la limitazione 
del mandato di coordinatore editoriale, una figura 
manageriale che è essenziale per riuscire a fornire 
in maniera regolare la rivista. Al coordinatore spetta 
"tirare le fila del discorso" pianificando prima e 
sollecitando poi la consegna dei vari contributi, 
arrivando alla "minaccia" per i ritardatari. Un compito 
che richiede molto tempo libero e che sarebbe giusto 

fosse diviso fra più persone. 
Dopo l'esperienza di start-up fatta da Tullio, anche 
Salvatore sarebbe giunto al termine del suo impegno, ma 
sostituirlo non è certo facile e d'altra parte, pur avendo 
l'amico Salvatore proposto un coordinamento ad interim 
fino alla decisione di chi se ne farà carico, riteniamo non 

sia giusto approffittare troppo. 
Qualcuno poi non se la sente, soprattutto per ragioni 
di lavoro, cosi tenteremo quest'anno un esperimento di 
coordinamento a rotazione. Comincerò io (Tullio) e poi 
seguiranno Sonicher, ancora Salvatore, Lorenzo e Bes. 
Non è che questa cosa "interna" avrà una ripercussione 
diretta sui contenuti della rivista, ma forse ognuno 
porterà un qualche suo apporto per arricchire 
ulteriormente l'offerta di contenuti e di fruizione del 

periodico. 

A questo proposito rimane sempre valido l'invito di farci 
pervenire le vostre osservazioni o i vostri "desiderata"; 
terremo conto di tutti i suggerimenti, come del resto 
abbiamo sempre fatto, nel limite ovviamente delle 

nostre possibilità. 

Buona lettura a tutti. 

[Tn] 


lunarie News 

è una fanzine 
dedicata al retro- 
computing nella più 
ampia accezione del 
termine. Gli articoli 
trattano in generale 
dell’informatica a 
partire dai primi anni 
‘80 e si spingono fino 
...all’altro ieri. 

La pubblicazione ha 
carattere puramente 
amatoriale e didattico, 
tutte le informazioni 
sono tratte da 
materiale originale 
dell’epoca o raccolte 
(e attentamente 
vagliate) da Internet. 

Normalmente il 
materiale originale, 
anche se “jarassico” 
in termini informatici, 
non è privo di 
restrizioni di utilizzo, 
pertanto non sempre 
è possibile riportare 
per intero articoli, 
foto, schemi, listati, 
etc..., che non siano 
esplicitamente liberi 
da diritti. 

La redazione e 
gli autori degli 
articoli non si 
assumono nessuna 
responsabilità in 
merito alla correttezza 
delle informazioni 
riportate o nei 
confronti di eventuali 
danni derivanti 
dall’applicazione di 
quanto appreso sulla 
rivista. 
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Retrocomputing 


Apple, Commodore, 
Sinclair, Atari,... va 
bene, ma gli altri? 

Quanti calcolatori 
sono stati costruiti 
e dei quali abbiamo 
sì e no una flebile 
traccia? 


Quello che ci siamo persi... 



Nelle immagini che 
illustrano l'articolo, 
alcune riproduzioni 
delle pagimne 
pubblicitarie della 
rivista Bit numero 20 
del 1981. 


M i è capitato di recente di 
venire ad una discussio¬ 
ne abbastanza accesa 
con un amico retro computerista, 
in merito alle macchine che sono 
state progettate e costruite e delle 
quali non abbiamo più traccia. 

Il mio amico sosteneva che queste 
non potessero essere poi moltissi¬ 
me e che semplici progetti hobbisti¬ 
ci o poco più non conservano gran¬ 
de interesse per il retro computing. 
La mia posizione era diversa e, se 
vogliamo dirla tutta, completamen¬ 
te antitetica alla sua: non solo ne 
sono stati costruiti molti di queste 


calcolatori, ma 

il fatto che non non diano più segno 
di se non li esclude dall’essere og¬ 
getti interessantissimi per il nostro 
hobby. Anzi, si potrebbe dire che la 
rarità ne costituisce il pregio. 

:-’’Stai parlando dei vari Compu- 
color, TRS-80, Amico-2000, etc...?” 
- mi chiede. A parte il fatto che il 
TRS-80, sebbene poco diffuso da 
noi è tutt’altro che una macchina 
sconosciuta, gli spiegai che mi ri¬ 
ferivo piuttosto a quei calcolatori 
che sono stati costruiti da piccole 
aziende, magari comprando i com¬ 
ponenti qua e la e realizzando sof¬ 
tware verticali come i gestionali e 
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poco altro. 

Simili software-house (vogliamo 
chiamarle così?) spesso vende¬ 
vano sistemi chiavi in mano con 
pochissimo software: giusto ma¬ 
gazzino e fatturazione, cose così, 
messe insieme o adattate alle spe¬ 
cifiche esigenze del cliente. 


Passando dalle parole ai fatti 
abbiamo sfogliato assieme una 
vecchia rivista di informatica: Bit, 
esattamente il numero 20 che è 
del settembre ‘81. 

Abbiamo così scoperto una spe¬ 
cie di cimitero dei dinosauri: so¬ 
prattutto la pubblicità è una fonte 
rivelatrice dell’esistenza (fossile?) 
di decine di calcolatori ormai persi 
nell’oblio. 

Sarebbe bello poter incontrare 
qualcuno che ce l’ha ancora in 
casa un “Ulisse-80”, uno “Zenit 
data System”, un “SuperBrain”, un 
“Vector System 3005”, un “Monroe 
EC4000”, un “Saga Fox”, oppure 
addirittura un “ABC-26” della Al 
Electronics Corporation Japan! 

Qualcuna di queste macchine 
si può trovare anche su Internet; 
è il caso del SuperBrain, eviden¬ 
temente bastantemente diffuso 
oltreoceano da aver generato un 
filone tutto suo nelle collezioni di 
retro calcolatori. Di altre, soprat¬ 
tutto se costruite o solo assembla¬ 
te in Italia, inutile cercarne traccia: 
vuoto assoluto! 

Quasi tutti questi progetti si ba¬ 
sano sulla CPU Z80. Questo è 


espressa- 
mente di¬ 
chiarato nel¬ 
le specifiche 
tecniche 
oppure lo si 
deduce dal¬ 
la presenza 
del CP/M o 
anche sem¬ 
plicemente 
dalla lista dei 
linguaggi di¬ 
sponibili. La 
comparsa 
di un FOR- 
TRAN-80 
o di un AL- 
G O L - 8 0 


6 punti in più che distinguono il 
personal computer dai personal 
computer 

1. MEMORIA 64k 4. IL MIGLIORE SOFTWARE 

2. MONITOR 12 POLLICI DI BASE 

3. SCRIVE MAIUSCOLO E 5. TUTTI I LINGUAGGI 

MINUSCOLO 6.CONSULENZA E ASSISTENZA 



Zenith, la differenza in più. 
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/A 
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\ 


nella lista dei sistemi di sviluppo 
acquistabili con la piattaforma, 
è chiarificatrice della tipologia di 
macchine offerte. 


Alcuni sistemi, come lo Zenit Data 


System e il 
Superbrain, 
dichiara la 
presenza di 
due micro- 
porocessori 
Z80, chissà 
per che far¬ 
ne... imma- 


Diecinque 

novità! 


HARDWARE 

• CPU Z80-A (4MHZ) 

• 64 KB RAM (standard) espandibili a t MB 

• Hardware Fcanna Pomi 

• Due Floppy Dlsc 8-inch (2.3MB) 

• Rea rime Clock! e Inreryal Timer 

• 2 Porte Seriali RS232 - C (SDLC/HDLC eie ) 

• CCIfT V24 AYSN BSYN IEEE-GP Interine* 

• Winchester, Floppy Aggiuntavi, Plotlor eie 

• Estensione di Memoria por gestione ri più 
terminali video e stampanti 



SOFTWARE 

• SISTEMI OPERATIVI: 

MP/M MULTIPROGRAMMIN3 OPER SYSTEM 
CP/M. DOSKET, UCSD PASCAL eie 


• LINGUAGGI DI PROGRAMMAZIONE 

BASIC 80 - MBASlC CBASIC 
COBOL 80 CON ACCEPT/DISPLAY 
FORTRAN IV • FORTRAN 80 
ASSEMBLER MACRO ASM 


•COMUNICAZIONI. 

IBM 3270 - IBM 3780 - MASP - TSSE 



gino che uno 


sia dedicato 
all’l/O visto 
che non sem¬ 
bra il caso di 
ipotizzare 
configurazio¬ 
ni multipro- 



cessore nel 


Diecinque 

Distributore esclusivo 
per l'Italia 


Sade e dtre^ono commerciale 

40009 Zola Propesa Bologne 
Via Nonnotii. t 
Tel (051) 752264 
Tela. 214546 OLC1N I 


Hi Electronics Corp. 

Tokyo Japan 
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un perfetta equilibrio 
psico-fisica 



FOX-microelaboratore italiano studiato per il mercato italiano. 

Un complesso, unico n Italia, di programmi applicativi pronti, installabili subito, 
aggiornati continuamente. FOx-miaoelatxiratore "small business" 
leader nella sua classe per il software di base. 

Piccolo per le piccole esigenze, grande per le grandi: 
per uso tecnico, didattico, gestionale e per l'informatica distribuita. 

Un perfetto equilibrio tra software e hardware per fare dei FOX "un sistema" 

jCU/SU completezza 
fi fu cil e continuità 


_ - Sawn Avarine GHttnriViendaie»SEDE Rbrn?Ma VBrtrx^-llei 8677<l MIO»613158SAGARM • F1UAU 

Boro. vn P.vvrtu, <3 lei 8S6ffi. «OTB-MynD vu Fu ir, r tri A V/bl »a|n> Ì3M>77 SAGAM • JTTA ITALIA 



A 


Grazie ancora 
amici, 
per la vostra bella 

accoglienza...” 


I— 

System 

1600 


System 

2600 


System 

3005 


System 

5005 



IMPORTATORE ESCLUSIVO 
PER L'ITALIA 

fccls. | 

compii u» dai a «mimi sul 

LIVORNO ■ TEL. 0S«6.3764* 



VECT0R GRAPHIC INC. 

COMPUTERS 

PER UN MONDO MIGLIORE 


CERCANSI RIVENDITORI PER ZONE UBERE 



Per altri progetti è più difficile de¬ 
durne la configurazione tecnologi¬ 
ca. Ad esempio il Monroe EC 4000 
non svela assolutamente nulla di 
particolare se non la dotazione di 
memoria RAM disponibile. 

I nomi di fantasia, dallo stile pale¬ 
semente scientifico (Compubioni- 
cs, ad esempio), sempre completi 
di sigle numeriche, fanno intende¬ 
re di essere difronte ad una mac¬ 
china proiettata nel futuro. 

La multiutenza è una frontiera: -”ll 
computer CTL 980 si fa in due...” 
che vuol dire semplicemente che 
ci potete attaccare due terminali. 
Sistema operativo e altri partico¬ 
lari non è dato saperlo (im magi- 
niamo sia basato su MP/M, l’unico 
sistema operativo in time-sharing 
disponibile per i micro. 

Beh, al termine di questa nostra 
carenata ci siamo trovati d’accor¬ 
do: -”Ce ne siamo persi parecchi, 
peccato!”. 


[Tn] 
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SENZA 

(lard Disk® 
Hard Diekf* 


DI MASSA E DI BACK-UP 


Packages applicativi 
a richiesta 
cercasi rivenditori 
per zone libere 

DISTRIBUTORI AUTORIZZATI 




Vi presentiamo il nuovo computer Monroe EC 4000. 


EC 40X) la realtà supera la fan¬ 
tasia. 

Provare per credere: baita 
che vi mettiate in contatto con 
l'ABL distributore esclusivo per 
l'Italia. 

Cosi, finalmente, il nuovo 
microcomputer Monroe EC 4000 


A B L S-p a Maa-Mnr e Suoni per Ufltao 301 22 MILANO - Volr Brainw VE*. 26 • Tel 02 $IM« - 5047» SOM» • Tde* JI5«J 



potrà presentarsi da sé. 



Questo è il nuovo micro- 
computer Monroe 4000. 

F appena arrivato dii II* America 

dalla Monroe. ed è il risultato 


ffl MONROE 

litro»* Svitami For Bunrmt 

della tecnologia piu avanzata del 
mondo. 

Compatto e potente, il mi- 
crocomputer Monroe EC 44KK) 
c piccolo come una macchina 
per scrivere mn ha una memoria 


RAM utente di 64 kbvtes, 
con doppio minifloppy disk per 
640 khytes. enn possibilità (ti 
espansione 

Provate a immaginare come 
sani semplice, con il Monroe EC 
4000 risolvere i vostri problemi 

di gestione, contabilita, ammini¬ 
strazione e fatturazione. 

Di Ironie al prezzo, poi. vi 
sembrerà di sognare ad occhi 
aperti invece c solo un rapporto 
ottimale prez7o-prrstazinni 

Insomma. con il Monroe 


Accesso casuale 



Il FOX 
della 
SAGA 





Il alalenta 6 pacevu» <ts!et«ca mente con 
•cocca comprendente (sMIcta. .*doo c 

Ojo floppy da 5 poma a in Quarto 
L architettura, monoscheoa. © casata su 
d ia rrucroaraceti son Z80 con od© da A 

MHJ di CU. uno declinalo «Ha gemono de. 
itic netti e Tauro com* unii» contrai© no 
deriva una ncrevole vitine»» rmoiHtvi 
la memoria 6 standard da B4 «Me ou 2 
Kbyte EPROW di nrmwi/o 
P-ewnta <r UK»1« un porto Mjr«le RS-232 
od un cono parallelo uNtzzato in uosa di 
massima e «ampante 
la 'astte'a 0 panicoiarmenlo Curala S^pro 
sema con « dUpoaixone stondard 
CWfRTV. tatiM'ino r^nùnco tooarato 
con tasto di »c*> zero Prolena contro gì» 
ingrossi "XlUpi. dotata di c»c*controllabile 
a software, presenta alcuni tasti «urrvnapili 
w per » controllo d. POWER ON de» RUN 
d«*e per»* eriche *i*i> Maio di MalUSCO» . 
Sia C« sognalazoru a programma l ac- 
co«>amento r»a tasti e caratteri 6 ntera- 
monte controllato a l.mwaro Ciùèpartlco- 
la-mente ulilo per quattordici tasti funzione 
che compilano ui tastiera con una roa 
apgiuntr*» n «Un ruminai, tu ad urs u«u di 
v^ira Piocestpng sia a persona unioni 

Il video da • 7 potici, di colore vera© e con 


ridarne presenta 24 rigo© oa 80 caratteri 
maiuscov e rranuacok ©d un se» di caratteri 
specalt modificatili a firmware 
Le -ttei.nate Ur mnoi prevede oue noppy 
•raseuno da <000 Koylri (doppio tosta e 
dcw>*a OanvtÉ) eppure un floppy ed u n 
draco fisso di tipo Winchester da 53 Mbyte 
» *oit*a/o © particolarmente cura» ed ab- 


gestlcnaii torneo chiavi in mano casa SA 
GA « Unguaggro <PL80).O© sia pe* la ver¬ 
sione e »oppy aia per quella a «v.rcneste» 
E «nnunciota un oitora-one dei BASIC che 

consenti'* armene rarriso a q » orchi* 
de lottwere SAGA 

il MJflMua a base elenca il natemi opera- 
tiv -0 CP/M. Il complesso de» Inguauili di¬ 
sponibili sudo 280 1 Basic. Fortran. Coboi i 
e »an emulatori p« telecomuncaziof'' 

La SAGA sta cibando la messa a ounto di 
un pacchetto d» Word Procossng che prò 
vele aggancio a routrw di calcolo e ad 
archi*, oó al» scopo di ooltegamco»*,: y,p 


procedure 
t annuno 


linguaggio di notevole semplicità 

I oiwomo è costruito con malenoii o po"te- 
rche quasi totalmente itatelo. e tutta esila¬ 
ra» © la progettatone pa noie spocifche 
czie oerrvano Orollamente dalle esperwn- 
n SAGA, sia necriarowB'o. è comunque 
evidente un oocn» onorilo allo sviluppo 

<»•© tecnologia ntcrnaocnae 

II prezzo di vendita è di 735 rnilpm nella 
trazione con 64 Kbyte e due rtoopy 


combura. 

co 400 Kl 


SAGA verso I" oHIeo auicmaticn " In coso 
sono oarlcolarmenie Curato lo funzioni d» 
introduzione doli oi ricerca negli archivi e 
di prepo'azKino di documenti a mezzodì un 


la SAGA, con un volume d» alta», «a circa 
10 miliardi 70 dipendo*! diretti, due flkah 
ouaaio consociato od oltre 35 concessio¬ 
nari ha svolto tino ad ora prevalentemente 
una polite» molta aii'EOP gesserete 
1 chlav* in maro 1 SI» ditforoniun-Oo lo suo 
attività da circa unannccoi »i word p-oces- 
sng ((teJrPuisce l amencano Nfii) e enn t 
satem. gretti a coleri «d «Ho Uvei» Idlitri- 
tiraco il ' rnstnr icari" rt«4a R»mt«w> 

Con 4 lane» oei FOX intendo nvdgersi a a- 


Per terrori n/o'tmuiOf» 
SAGA 

Va V Bottini. 24 


La KYBER CALCOLATORI ti offre 
piccoli e grandi sistemi di elaborazione, 
personal c unità in multiprogrammazionc e in multiprocessor. 
In tutti i linguaggi di programmazione. 

Progetta e produce in Italia 
usa le tecnologie più avanzate, 
attua yna politica di basso costo. 




La KYBER c dalla tua parte! 


^ ■KYBER 

^■cacciatori 

SISTEMI 01 ELABORAZlOf* DATI 


CONCESSIONARI KYBER CALCOLATORI 


ASCOUMCINO 


OtHOV» 



SI CERCAMO COMCESSIOMARI PER LE ZONE LIBERE 
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L e prò ve di Jurassic Ne ws 

Silicon Graphics - Indigo 


Quando l’informatica 
personale ha 
cominciato davvero 
a incidere dove 
prima non era 
immaginabile 
arrivare, allora 
nacquero delle 
aziende che 
puntavano sulla 
qualità dei loro 
prodotti. Una di 
queste fu Silicon 
Graphics. 


Già dal colore 
si capisce che 
questo non è un 
normale PC vestito 
da workstation... 

E' l'Indigo di 
Silicon Graphics, 
praticamente una 
leggenda! 



dei PC la Intel ha già presentato il 
486, ma sul mercato impazzano i 
386SX a 20-25 MHz che permet¬ 
tono alle ditte di smaltire tutta la 
vecchia componentistica AT a 16 
bit. Ci sono ancora in uso moltissi¬ 
mi 8086 e 80286, e gli sviluppatori 
aspettano il momento in cui ci sarà 
un 386 su ogni scrivania. Gli hard 
disk hanno una capienza tipica in¬ 
torno ai 40 MegaBytes. La Apple 
propone il Macintosh LC, con un 
Motorola 68020 a 16 MHz e grafica 
a colori da 512x384 pixel. La Mi¬ 
crosoft presenta la versione 5.0 di 
MSDOS, limitata come sempre a 
640 Kbytes, mentre Windows è an¬ 
cora alla versione 3.0, che è poco 
più di uno Shell grafico e ha un con- 


Contesto storico 


P rendete un profondo re¬ 
spiro, chiudete gli occhi 
e fate un rewind mentale 
fino al 1991. Ci siete? 

Facciamo mente locale. Il Presi¬ 
dente del Consiglio è Andreotti. Lo 
scudetto lo vince la Sampdoria, il 
mondiale di Formula 1 Ayrton Sen¬ 
na. Edwige Fenech presenta il festi¬ 
val di Sanremo. In Kuwait scoppia 
la prima guerra del golfo. I Metalli¬ 
ca incidono Nothing Else Matters. 
Muore Freddy Mercury. 

Il mercato degli home computer 
è saldamente in mano alle varie 
versioni dell’Amiga. Nel settore 


8 










Jurassic News - Anno 5 - numero 27 - gennaio 2010 


corrente temibile in OS/2; tra l’altro 
non supporta in alcun modo la rete 
locale e non lo farà fino al 1993. 
Internet non è ancora il www (che 
viene presentato proprio quest’an¬ 
no) e viene usato solo dagli addetti 
ai lavori. Esistono invece i BBS, a 
cui si accede via telefono e mo¬ 
dem; naturalmente non i modem di 
ieri a 56 Kbaud ma quelli di allora, 
a 300 o 1200 baud. Nella grafica si 
sono ormai imposte le schede VGA 
(640x480 con 16 colori, nessuna 
accelerazione 3D), che vengono 
prodotte in modelli incompatibili da 
una infinità di piccole ditte (Orchid, 
Paradise, Cirrus ecc.ecc.). I drives 
CD-ROM non esistono e le schede 
audio sono ancora rare. 

Naturalmente per usi professio¬ 
nali esistono, come sempre, mac¬ 
chine di categoria superiore. Dopo 
la prova generale con The Abyss 
(1989), la computer graphics entra 
infatti quest’anno nella storia del 
cinema con Terminator 2 mentre 
è in lavorazione la pietra miliare di 
Jurassic Park, che uscirà due anni 
dopo. Dietro gli effetti speciali cine¬ 
matografici troviamo in pratica una 
sola ditta: la Silicon Graphics. In 
particolare il suo modello più lega¬ 
to alla produzione di Jurassic Park 
verrà prodotto in seguito, con una 
certa ironia, anche nella versione 
limitata Jurassic Classic. 


La Silicon Graphics Ine. 



La Silicon Graphics è da sempre 
specializzata in sistemi professio¬ 
nali high-end. Nel 1988 ha fatto 
con la sua Personal Iris un primo 
tentativo di introdursi in una fascia 
di mercato più bassa, riuscito solo 
parzialmente: la Personal Iris è 
impressionante ma costa ancora 
molto, almeno 25.000 U$. Ora, 
nel 1991, presenta una nuova 
macchina per lo stesso target. Il 
costo è ancora lontano dal mon¬ 
do PC, partendo da un minimo 
di 10.000 U$ dell’epoca, ma non 
assurdo per un uso professionale. 
E un confronto coi PC coevi è im¬ 
possibile: già la prima versione ha 
un processore RISC MIPS R3000 
a 33 MHz (ma sarà subito affian¬ 
cato dal nuovo R4000 a 100 MHz) 
con CPU+FPU, monta fino a 16 
Mbytes di 
RAM e fino 
a tre Hard 
Disk SCSI 
veloci per 
una capaci¬ 
tà di diversi 
Gbytes. La 
risoluzio¬ 
ne grafica 
è fissa a 
1280x1024 
pixel, con 
16 milioni di 
colori e ac¬ 
celerazione 
hardware. 

Il suono, 
stereo, è 


(Figura 1) 

Negli anni '80 e 
'90 BYTE era la più 
autorevole rivista 
USA per il personal 
computing. In 
copertina nel numero 
di Settembre la 
Indigo in tutto il suo 
splendore. Da notare 
la preview di Windows 
3.1! 
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affidato ad un Digital Signal Pro¬ 
cessor Texas Instruments 56000. 
Un’interfaccia thick-ethernet AUI è 
di serie. Il sistema operativo è una 
variante di Unix stabile ed efficien¬ 
te, con una bella interfaccia grafi¬ 
ca WIMP (windows-icons-mouse- 
pointer). 

E’ la Silicon Graphics Indigo, che 
conquista subito la copertina di 
BYTE del Settembre 1991. 


Primo approccio 


(Figura 2) 

Uno sportello molto 
discreto permette 
l'accesso ai dispositivi 
rimovibili. 


La Silicon Graphics non ha mai, 
in tutta la sua storia, prodotto una 
macchina beige. La Indigo è ap¬ 
punto blu scuro (Indaco!), compat¬ 
ta e squadrata, percorsa da sottili 
feritoie di raffreddamento. Larga 
25cm, alta 38 e profonda 30, la In- 
digo è a parere di molti la macchi¬ 
na più bella mai prodotta da Silicon 
Graphics - che non è poco, consi¬ 



derata la qualità dell’industrial de¬ 
sign di questa casa, paragonabile 
solo a quello di Apple. Anche la 
qualità costruttiva non ha niente 
in comune coi PC: la macchina, 
come quasi tutte le Silicon che se¬ 
guiranno, è interamente contenuta 
in un telaio d’acciaio che sembra 
in grado di resistere ad un rien¬ 
tro in atmosfera, ricoperto da un 
guscio esterno in plastica che ha 
solo funzioni estetiche e che la 
Casa chiama con sufficienza skin, 
pelle. Con un solo hard disk mon¬ 
tato pesa già 17 Kg. 

Uno sportello molto discreto per¬ 
mette l’accesso ai dispositivi ri¬ 
movibili (Figura 2). Nel caso della 
macchina in prova l’unità raggiun¬ 
gibile aprendo lo sportello frontale 
è un DAT montato sullo slot supe¬ 
riore. 

Il badge giallo in basso a sinistra 
indica che la macchina è una In- 
digo R4000 Elan. In teoria tutte le 
R4000 avevano una badge colora¬ 
ta di identificazione, di forme e co¬ 
lori diversi a seconda delle schede 
grafiche installate. In pratica quasi 
tutte le Indigo sono state modifica¬ 
te in qualche modo, non sempre 
coerente con l’aspetto esterno. 

A parte un backplane di colle¬ 
gamento, che contiene anche le 
interfacce parallela e SCSI, tutta 
l’elettronica è concentrata in due 
grandi schede a innesto rapido. 
Una contiene la CPU, la memoria, 
la rete, tutte le interfacce tranne 
l’uscita video e due slot di espan¬ 
sione proprietari; la seconda è la 
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scheda grafica con i suoi connetto¬ 
ri. Il pannello frontale si smonta con 
due pulsanti e all’interno non c’è un 
solo filo volante: tutto, alimentatore 
incluso, è montato su slitte ad inne¬ 
sto diretto sul backplane, e tutto si 
smonta e si rimonta senza attrezzi. 
Avendo i ricambi adatti, una Indigo 
guasta può essere rimessa on-line 
in due minuti e a mani nude. 


Hardware 


In realtà la configurazione che 
abbiamo descritto è solo una del¬ 
le infinite possibili. La Indigo è da 
considerarsi più un sistema che un 
modello, e sotto una identica ap¬ 
parenza esterna possiamo trovare 
strutture completamente diverse. 



La scheda CPU+FPU, che inizial¬ 
mente ospita un processore R3000 
a 33 MHz, viene subito ridisegnata 





in modo da accoglie¬ 
re il nuovo processo¬ 
re R4000 a 100 MHz 
(e poi il successivo 
R4400 a 150 MHz) e 


(Figura 3) 

Rimuovendo il frontale 
si nota a sinistra 
lo stretto sportello 
verticale che accoglie 
la scheda CPU e la 
scheda grafica. 


molta più RAM. Può 


montare fino a tre 


hard disk, ma due di 
questi possono esse¬ 
re sostituiti da un flop¬ 
py da 3,5” e/o da uno 
speciale floppy ma- 
gneto-ottico (il flopti- 
cal) da 21 MBytes e/o 
da una unità a nastro 


(Figura 4) 

Lo sportello schede 
si apre verso il basso 
rivelando il fianco 
delle schede inserite 
negli slot. 


DAT da 2 GBytes. La 
scheda grafica può 
anche mancare del 


tutto se la macchina 
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(Figura 5) 

Il pannello posterio¬ 
re con le uscite “built- 
in” e quelle messe 
a disposizione dalle 
schede inserite. 


viene usata 
come server, o 
può essere una 
scheda entry- 
leve I piuttosto 
spartana, ma 
più spesso è la 
scheda modu¬ 
lare GR. Que¬ 
sta è basata 
su diversi PCB 
e sembra fatta 
coi Lego: può 
essere equi¬ 
paggiata (e/o 
espansa suc¬ 
cessivamen¬ 
te) con uno o 
con tre piani 
di RAM, per 
avere rispet¬ 
tivamente 256 colori o 16 milioni 
di colori; può avere o non avere 
uno Z-buffer per assistere il ren¬ 
dering 3D; può montare uno, due 
oppure quattro Geometry Engines 
che eseguono in hardware le tra¬ 
sformazioni geometriche, più un 


acceleratore raster (il Raster Engi¬ 
ne) che è sempre presente; è pre¬ 
disposta per il video stereo 3D in 
hardware. La versione “full optio¬ 
nal” di questa scheda, con 24 bpp, 
Z-buffer, Raster Engine e quat¬ 
tro Geometry Engines si chiama 
Elan, e fa una certa figura ancora 
oggi. Una conseguenza di questa 
componibilità è che oggi è difficile 
trovare due Indigo uguali, perfino 
provenienti dallo stesso ufficio. 

Nella figura 2 è possibile notare 
a destra, dall’alto, l’alimentatore 
(su cui sono fissati anche l’altopar¬ 
lante e il grosso pulsante di reset) 
e i tre slot per dischi e nastri, tutti 
montati su slitta. 

Nella figura 3 la macchina aperta 
mostra le schede inserite negli 
slot. Nella scheda video, quella 
più a destra, si notano alcune 
delle “daughterboards” che costi¬ 
tuiscono la configurazione Elan. 
Uno dei dischi fissi è parzialmente 
estratto. 


(Figura 8) 



Fratelli? Gemelli! 

La Indigo infatti è 
stata venduta - sen¬ 
za alcuna modifica 
se non la marca e il 
colore - anche dal¬ 
la rete commerciale 
di altri costruttori: in 
questo caso Control 
Data Corporation e 
Siemens-Nixdorf. 
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Il pannello posteriore (Figura 6) 
non è particolarmente ordinato. 
Nella scheda video (la serie di con¬ 
nettori a sinistra) troviamo, dell’al¬ 
to, il connettore 13w3, un BNC per 
il genlock e un mini-DIN per gli oc¬ 
chiali stereo CrystalEyes. 

A fianco, cinque connettori mini¬ 
jack per microfono, linea in, linea 
out, cuffie e audio digitale (I); due 
porte seriali RS232 con connetto¬ 
ri mini-DIN compatibili Macintosh, 
un terzo mini-DIN perla tastiera ed 
il 15-pin della rete thick ethernet. 

Più in basso il DB-25 della porta 
parallela e al centro il grosso SCSI 
50-pin. I due pannelli metallici più 
piccoli a destra, coprono gli slot di 
espansione dedicati. 

Per fare a meno del video con 
uscita 13w3 e collegarci un VGA, 
è necessario disporre di un adat¬ 
tatore come quello mostrato nel¬ 
la figura 7 assieme all’adattatore 
AUI-RJ45 per utilizzare l’attuale 
standard di collegamento per la 
rete ethernet. 




Software 


Il sistema operativo si chiama 
Irix, è la versione Silicon Graphics 
di Unix e segue piuttosto da vici¬ 
no la varietà AT&T piuttosto che 
la BSD favorita da altri costrutto¬ 
ri. Naturalmente ne esistono mol¬ 
te releases successive; in origine 
le Indigo montavano Irix 4.0, ma 
praticamente tutte sono state ag¬ 
giornate a qualche versione suc¬ 
cessiva. Le Indigo con processore 
R3000 possono accettare soltanto 
fino alla versione 5.3; sulle R4000 
è più comune trovare la 6 . 2 , ma 
una R4000 Elan può reggere bril¬ 
lantemente fino alla release 6.5.22 
del 2003 (adesso pensate a come 
girerebbe Windows 2003 su un PC 
del 1991, e ridete). L’ultima versio¬ 
ne di Irix, gestibile solo da macchi¬ 
ne successive, è del 2006. 


(Figura 6) 

Un dettaglio della 
scheda CPU di una 
Indigo R3000. I due 
chip dorati NEC sono 
la CPU R3000A-33 e 
la FPU R3010A-33, 
che non hanno biso¬ 
gno di dissipatori. 


(Figura 7) 

Adattatore video e 
retesono due acces¬ 
sori ormai indispen¬ 
sabili per chi ha un 
Indigo e vuole usarlo 
con le attuali tecnolo¬ 
gie video e di rete. 
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Running power-on diagnosti».. 



o caricare un interprete di coman¬ 
di provvisorio. Il caricamento di 
Irix impiega qualche minuto, ma 
occorre ricordare che questa non 
era pensata per essere una ope¬ 
razione frequente e che anzi la 
casa consigliava esplicitamente di 
lasciare sempre accesa la macchi¬ 
na, in modo che durante la notte 
potesse eseguire automaticamen¬ 
te determinate operazioni di hou- 
sekeeping. Infine viene caricato 
un menu grafico che elenca sotto 
forma di icone gli utenti autorizzati 
al log in (figura 10). 


La schermata 
iniziale di benvenuto. 


(Figura 10) 

Il menu di servizio 
cui si accede se 
si interrompe il 
caricamento del 
sistema operativo. 


All’accensione la macchina emet¬ 
te un caratteristico motivo musi¬ 
cale e lancia il self-test (figura 9). 
Le Silicon Graphics non hanno un 
BIOS; all’accensione eseguono un 
programma in ROM che provve¬ 
de al caricamento di Irix dall’hard 
disk e permette, volendo, di inter¬ 
rompere l’avvio per operazioni di 
manutenzione quali aggiornare il 
sistema operativo, eseguire un ri¬ 
pristino del sistema, effettuare una 
verifica approfondita dell’hardware 


u 

J 


Start System 

Instali System Software 

Run Diagnostics 


Recover System 


■I Enter Command Monitor 


W t L C O VI E 





Fatto il log in appare il desktop, 
che presenta in alto a sinistra il 
menu (chiamato Toolbox) delle 
operazioni più comuni e una serie 
di icone allineate lungo il margine 
destro. Nel Toolbox sono presen¬ 
ti, tra le altre cose, l’Icon Catalog 
che raccoglie in cartelle separate 
le applicazioni installate (di serie 
è inclusa una ricca serie di Utilities 
e parecchi demo, tra cui il gioco 
Doom) e un System Manager gra¬ 
fico che dà una interfaccia visuale 
a tutte le funzioni di amministrazio¬ 
ne, incluso il controllo completo dei 
processi, del filesystem e la crea¬ 
zione e la gestione di volumi logici 
estesi su diversi dischi fisici. 

Ovviamente colori, sfondi, fonts e 
persino le dimensioni delle icone 
sono personalizzabili. Bisogna am¬ 
mettere che per lo sfondo desktop 
sono disponibili poche possibilità, 
quasi tutte di rara bruttezza, e per¬ 
sino nelle versioni più recenti non è 
previsto in alcun modo che l’uten¬ 
te aggiunga sfondi extra. In realtà 
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questo è possibile, con un piccolo 
back che per i motivi appena espo¬ 
sti si impara molto presto. 

Irix è, naturalmente, molto stabile 
e concepito per girare ininterrotta¬ 
mente 24/7. Ha tutti i soliti vantag¬ 
gi di Unix con una serie di Utilities 
esclusive che lo rendono molto co¬ 
modo da amministrare: per fare due 
soli esempi, il comando chkconfig 
che permette di controllare, avvia¬ 
re e fermare individualmente i da- 
emons con una facilità disarmante, 
e un sistema di installazione del 
software a pacchetti pressoché 
identico ai package manager at¬ 
tuali di Linux. 

La documentazione è eccellente 
e tutti i (molti) manuali disponibi¬ 
li, che su carta riempirebbero uno 
scaffale, sono preinstallati in for¬ 
mato elettronico. La GUI è garan¬ 
tita da X-Windows e dal window 
manager proprietario 4Dwm. 

Irix richiede un mouse a tre ta¬ 
sti; non riconosce la rotellina, ma 
in cambio può montare diversi di¬ 
spositivi di input tra cui manopole, 
arrays di pulsanti e il particolare 
Spaceball a sei assi. 

In qualche punto I’hardware della 
Indigo dimostra tutta la sua età. È 
forse l’ultimo computer ad avere un 
“vero” interruttore di accensione: 
tutte le Silicon successive avranno 
infatti non solo lo spegnimento via 
software a cui siamo oggi abituati, 
ma anche la capacità di riaccen¬ 
dersi autonomamente ad un orario 
programmato. 



La scheda video GR non solo 
usa uno speciale connettore detto 
13w3 che richiede un adattatore 
per essere collegato ad un monitor 
moderno, ma trasmette i segnali di 
sincro sovrapposti al segnale del 
verde (SOG, sync-on-green). 

Il connettore 13w3, che prevede 
tre contatti RGB e dieci contatti au¬ 
siliari, era abbastanza diffuso an¬ 
che tra altri costruttori (SUN, HP, 
IBM ecc.) ma non è mai stato com¬ 
pletamente standardizzato e la fun¬ 
zione dei contatti ausiliari varia non 
solo da marca a marca ma persino 
da modello a modello, cosicché un 
adattatore non-specifico potrebbe 
anche funzionare come anche no. 


(Figura 11) 

Il desktop, ancora 
piuttosto povero, di 
Irix 4.0. Il program¬ 
ma grafico 3D in pri¬ 
mo piano (che non è 
di serie) è l’applica¬ 
zione originale che 
appare nelle scene 
finali di Jurassic Park 
(ricordate la scena? 
“Questo è un siste¬ 
ma Unix... io lo cono¬ 
sco!”). 


Un vero pericolo poi è il connetto¬ 
re della tastiera (alla quale si col¬ 
lega in cascata il mouse), che fisi¬ 
camente è un mini-DIN PS/2 ma 
ha voltaggi e connessioni incom¬ 
patibili. In questo modo è possibile 
connettere per errore alla Indigo 
una tastiera PC, con conseguenze 
tragiche. 
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(Figura 12) 

Il desktop di Irix 
6.2. In evidenza il 
System manager 6.2 
e, a destra, il sistema 
di documentazione 
InSight con i 
numerosi manuali 
on-line. 


Il resto è storia... 


Cosa ne è oggi della casa produt¬ 
trice? Sotto molti aspetti la Silicon 
Graphics ha semplicemente fatto 
la storia della Computer Graphics. 
Negli anni successivi ha cambiato 
nome in SGI e complessivamente 
ha prodotto molti altri modelli, alcu¬ 
ni dei quali, come la Indy e la 02, 
sono stati un successo planetario 
(curiosamente sono anche le mac¬ 
chine meno performanti). All’altro 
estremo della gamma vanno ri¬ 
cordati modelli incredibili come il 
supercomputer grafico Onyx2, in 
grado di ospitare fino a 64 CPU 
e tre canali video Infinite Reality 
multiplexati in grado di compor¬ 
re su tre megaschermi affiancati 
un’unica immagine panoramica in 
stereo. 


I processori MIPS ed i loro com¬ 
pilatori hanno mantenuto presta¬ 
zioni elevatissime ma alla fine 
hanno perso la battaglia dei costi, 
e le ultime macchine MIPS-based 


sono uscite di produzione nel 2006 
insieme all’ultima release di Irix. 
Come HP e Apple anche SGI è 
passata alla piattaforma Intel, e a 
Linux come sistema operativo. 

Dopo un difficile periodo di ammi¬ 
nistrazione controllata la SGI si è 
riconfigurata come fornitrice di si¬ 
stemi di memoria e server di alta 
classe e alta affidabilità. La grafi¬ 
ca ha rivestito un ruolo sempre più 
marginale nella sua attività finché, 
nel 2009, l’intera sezione grafica 
è stata chiusa. Sic transit gloria 
mundi. 

Sul fronte software la SGI ci ha 
lasciato, tra l’altro, lo standard 
Open GL, e dobbiamo alla sua 
opera pionieristica le schede gra¬ 
fiche dei PC attuali: Nvidia è stata 
fondata da ex-dipendenti SGI. 

In retrospettiva la Indigo è stata 
una macchina capace di presta¬ 
zioni notevoli ma anche, per certi 
versi, una macchina di transizio¬ 
ne che dopo solo due anni si è 
sdoppiata nei modelli lndigo2 e 
Indy. Inoltre (e purtroppo) oggi il 
suo case grande ed elegante è 
anche appetito dai modder, che 
lo svuotano per inserire al suo in¬ 
terno un PC moderno. Come tutti i 
retrocomputer non ha un valore di 
mercato definito: chi scrive se ne 
è vista offrire una gratis e un’altra 
(incompleta!) a oltre 200 euro su 
Ebay. Ma forse la cosa più sor¬ 
prendente è che alcuni rivenditori/ 
appassionati mantengono un vero 
e proprio magazzino di diversi 
modelli Silicon Graphics e relativi 
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componenti, il che rende ancora 
possibile, dopo quasi vent’anni, 
ordinare una Indigo nella configu¬ 
razione preferita come si farebbe 
con un normale PC. La SGI ha in¬ 
fatti un seguito di entusiasti picco¬ 
lo ma accanito, persino incredibile 
per macchine che non sono quasi 
mai state vendute direttamente al 
pubblico. 

Nel giro dei retro-computeristi fe¬ 
deli a questa marca viaggia ancora 
molto freeware e shareware ag¬ 
giornato e, volendo, una Indigo sa¬ 
rebbe ancora perfettamente usabi¬ 
le per svariate applicazioni (o per 
navigare, installando una versione 
recente di Firefox). 


C’è tuttavia un uso in particolare 
che ci sentiremmo di suggerire: se 
ci si riesce a procurare e installare 
un programma per la riproduzione 
di files mp3, il vecchio DSP Texas 
56000 della sezione audio fa anco¬ 
ra paura e non occorre essere un 
audiofilo raffinato per sentire la dif¬ 
ferenza di resa sonora con un PC 
Windows. Provare per credere. 

[Mr] 


(Figura 13) 

Ancora il desktop 
6.2 (ma il più recente 
6.5 è pressoché 
identico) con il 
raccoglitore Icon 
Catalog aperto sulla 
tab Demos. In alto 
a destra il “demo di 
demo” buttonfly, che 
era un vero e proprio 
biglietto da visita per 
Silicon Graphics. 
Ricordo che ne 
esisteva anche un 
clone per Amiga - 
per la serie “vorrei 
ma non posso”. 
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Rubrica curata da [Bs] 



Storie di vita dove i 
computer (soprattutto 
retro computer) 
c’entrano in qualche 
modo. 


U na sera il titolare della dit¬ 
ta dove ero ospite e sta- 
gista mi venne a trovare 
nell’alberghetto dove alloggiavo, 
almeno questo a spese del mio fu¬ 
turo datore di lavoro, e mi chiese se 
potevo l’indomani dare una mano 
a lui e ai ragazzi per andare poco 
lontano a ritirare della “roba”, così 
disse. Naturalmente accettai sen¬ 
za che mi passasse nemmeno per 
l’anticamera del cervello che que¬ 
sta attività poco aveva a che fare 
con un mio allenamento all’elettro¬ 
nica, ma tant’è la mattina si partì 
presto, saranno state le sette, con 
due furgoni alla volta di una impre¬ 
cisata località sul Garda. 

Arrivammo nella nebbia autunnale 
in un posto che mi sembrò dimen¬ 
ticato da Dio dove stava una spe¬ 
cie di stamberga, almeno così mi 
parve, con una scritta che recitava 
“Albergo delle Rose”, malmessa 
essa stessa, tanto che ricordo per¬ 
fettamente che il nome lo ricavai 
non già dalla presenza delle lettere 
dell’insegna, quanto dal colore di¬ 
verso che aveva la tinteggiatura in 
corrispondenza di quelle mancanti 
che erano la maggior parte. 

Qui in uno scantinato raggiungi¬ 
bile con una doppia rampa di scale 
strette di grezzo cemento, stavano 
depositati tre biliardi, uno smonta¬ 


to e due interi. L’ambiente la dice¬ 
va lunga sulla destinazione d’uso 
di un simile locale, evidentemen¬ 
te abbandonato in tutta fretta per 
qualche motivo: divani di vistosa 
plastica rossa e gialla (dico davve¬ 
ro, gialla!), tavolini coperti di panno 
verde, adibiti evidentemente al gio¬ 
co, sedie di una qualche velleità di 
comodità visto che erano imbottite 
di un velluto viola difficilmente ac¬ 
costabile a qualsiasi arredamento 
che non fosse adatto ad un bor¬ 
dello. Michele suggerì che doveva 
essere lo stesso posto oggetto di 
una irruzione della Polizia un paio 
di anni prima. Sembra si trattasse 
di un vero e proprio covo dove av¬ 
veniva di tutto, comprese partite a 
biliardo evidentemente, non saprei 
dire con quale scopo o posta. 

In quel posto il nostro titolare sve¬ 
lò lo scopo del viaggio: -“Portia¬ 
mo via questi due biliardi e quello 
smontato che c’è li”, boforchiò, in¬ 
dicando con un cenno del capo un 
cumulo che a me sembrava di ma¬ 
cerie ma che evidentemente ad un 
esame più attento evidenziavano 
immancabilmente l’origine. “Portia¬ 
mo” aveva detto il Nostro Duce, ma 
non seguì alla lettera la sua stessa 
dichiarazione, nel senso che NOI 
portammo su la roba, lui sparì con 
la persona dall’aria equivoca che 
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aveva aperto la porta del tugurio. 

Non so quanto siate pratici di bi¬ 
liardi ma certo avrete avuto la sen- 
zazione toccandone uno che siano 
molto massicci. E’ così! Visto che il 
piano deve essere liscio al massi¬ 
mo e assolutamente stabile, ne se¬ 
gue che è realizzato mettendo as¬ 
sieme a seconda della dimensione 
del piano stesso, da quattro a otto 
lastre di pesantissima ardesia levi¬ 
gata della dimensione di circa un 
metro quadrato cadauna e spesso¬ 
re dai quattro agli otto centimetri. In 
tre non riuscimmo ad alzare la pri¬ 
ma che stava appoggiata al muro 
e subentrò lo sconforto. Che fare? 
Non eseguire sarebbe valso ad un 
ammutinamento in piena regola con 
conseguenze spiacevoli per tutti e 
tre (Salvatore mica era venuto, lui 
era troppo furbo per farlo!). 

Disponevamo di un carrello a due 
ruote, più adatto al trasporto delle 
cassette di frutta che di un simile 
peso. Quando riuscimmo a trasci¬ 
nare la prima piastra sul carrello le 
ruote dello stesso si abbassarono 
di una buona metà, a riprova che 
non c’era nulla da scherzare. 

In ogni caso eravamo tre baldi gio¬ 
vani: Michele, Andrea e io. Certo la 
forza non ci mancava, per cui con 
rara abnegazione che nessuno al 
giorno d’oggi crederebbe possibile, 
trascinammo il primo pesante far¬ 
dello su per le due rampe di scale 
e da li dentro il furgone. Rimaneva¬ 
no altre cinque piastre dello stesso 
peso, poi le gambe e le fiancate e 
poi due altri biliardi interi, e per quel 
primo viaggio avevamo impiegato 


mezz’ora buona! 

Il secondo viaggio andò peggio, 
nel senso che la piastra si scheggiò 
in un angolo, il terzo fu parimenti fa¬ 
ticoso e a quel punto noi eravamo 
assolutamente esausti e certi di non 
essere in grado di portare a compi¬ 
mento l’arduo compito. Ci sedem¬ 
mo quindi sulle scale di cemento 
per prendere fiato e naturalmente, 
dato che il diavolo ci mette sempre 

10 zampino, capitò subito il titolare 
assieme ad una tizia dall’aria vol¬ 
gare, anche se giovane e certo non 
brutta come fisico, che fumò tutto 

11 tempo una sigaretta dopo l’altra 
mentre si accalappiava sul prezzo 
che il nostro capitano avrebbe do¬ 
vuto sborsare per liberarla di quel 
pesante ingombro. 

Noi naturalmente facevamo finta 
di proseguire la lotta con l’improbo 
mostro attaccando la piastra nume¬ 
ro quattro del nostro calvario. Tizia¬ 
no prima finse di darci una mano 
e poi si rivolse alla sventurata ci¬ 
miniera umana per continuare le 
sue trattative al ribasso sul prezzo 
del materiale. Arrivati a metà della 
scala il Nostro ci intimò di riportare 
tutto indietro, evidentemente per le 
conseguenze del mancato accor¬ 
do sul prezzo. Il tira e molla andò 
avanti per un pezzo con noi che fa¬ 
cevamo dietro front su quelle sca¬ 
le ora salendo ora discendendo in 
relazione all’umore della trattativa. 
Alla fine decidemmo di rimanere sul 
pianerottolo e di non muoverci più, 
cascasse il mondo! 

Il mondo non cascò naturalmente 
e dopo un’ora ci rivide arrancare 
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con il nostro fardello su quella sca¬ 
la che divenne per me simbolo del¬ 
la più assoluta e inutile sofferenza 
umana. 

Il titolare non partecipò all’impre¬ 
sa, se non chiamando il colpo al 
momento di caricare, per criticare 
come avevamo sistemato le piastre 
sul furgone e imprecare per la no¬ 
stra lentezza nel compiere le ope¬ 
razioni che lui, a suo dire, aveva 
fatto centinaia di volte. Si accorse 
della piastra sbeccata e dato che 
le bestemmie pronunciate all’indi¬ 
rizzo di tutti i santi del Paradiso, noi 
compresi, non ebbero efficacia tale 
dal riparare il danno, volle di nuovo 
ridiscutere il prezzo con la megera 
di prima adducendone il motivo alla 
scoperta della magagna. 

Da parte nostra eravamo arrivati a 
quello che credevo potesse essere 
il limite della sopportazione umana, 
senza sapere che l’uomo ha risor¬ 
se tali e a lui insospette, da portarlo 
ben oltre questo limite. 

La megera venne, si rese con¬ 
to del danno e sentenziò che era 
stato fatto da noi medesimi e che 
la scheggiatura era recente. La 
sua competenza ci lasciò allibiti e 
ancora di più ne fummo sorpresi 
quando con astuzia rifece il percor¬ 
so delle scale e individuò il punto 
esatto dove era avvenuto il fattac¬ 
cio. Noi avevamo buttato il pezzo 
grosso della scheggiatura ma non 
certo raccolte tutte le schegge che 
si erano generate. 

lo e Andrea stemmo zitti mentre 
Michele, anima candida, confessò 


confuso il nostro fallo e a noi non 
rimase che annuire. 

La megera parlò tenendo la siga¬ 
retta in bocca e con soddisfazione 
che non si preoccupò minimamen¬ 
te di celare, ci redarguì come fossi¬ 
mo ragazzini che dicevano bugie. 
Pivelli lo eravamo di sicuro e quella 
inquietante, per noi novellini, figura 
femminile ci faceva un effetto par¬ 
ticolare: ce ne stemmo zitti a testa 
bassa dopo aver confessato il pec¬ 
cato a quello che manco lontana¬ 
mente si sarebbe potuto scambiare 
per un prete. Tacemmo e ripren¬ 
demmo il lavoro, certi di non esse¬ 
re ormai più in grado di protestare 
alcunché. 

La “signora”, sempre con la siga¬ 
retta in bocca ci guardava arranca¬ 
re per le strette scale e biascicava 
talvolta degli inviti a stare attenti e 
a non sbattere le sponde contro il 
muro. A me parse che ci prendes¬ 
se in giro e lo dissi a Michele che 
ne convenne. Andrea disse che se 
era così lui se ne sarebbe andato, 
al diavolo le conseguenze (era gio¬ 
vane, lo perdonammo). 

Poi la megera, così come era ve¬ 
nuta, cioè fumando, salì le scale e 
sparì dalla vista. Lasciati i propositi 
di rivolta o incrocio delle braccia, 
trasportammo di slancio le ultime 
due piastre del primo biliardo e tutti 
gli altri pezzi che si rivelarono al¬ 
trettanto pesanti e ingombranti su 
quelle strette scale. 

Intanto era arrivato un tizio, evi¬ 
dentemente uomo di fiducia della 
padrona, che si mise con il nostro 
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titolare a smontare i due bigliardi 
ancora interi. 

L’oggetto era un po’ più piccolo di 
quello che avevamo caricato e di 
quello che rimaneva ancora integro 
nel locale, per cui ci illudemmo che 
sarebbe stato meno pesante: errore 
clamoroso! Il piano era di sole quat¬ 
tro piastre ma ENORMI! Dichiaram¬ 
mo senza pericolo di smentita che 
non ci sarebbero mai passati su per 
le scale e il nostro Duce non potè 
che constatarne la fondatezza di 
questa affermazione. 

Ipotizzo di togliere le ringhiere 
in ferro per far transitare l’ingom¬ 
brante fardello, ma convenne che 
avremmo dovuto segarle, dato che 
erano cementate alla base. 

Il nuovo venuto si scrollò nelle 
spalle rivelando che c’era un’altra 
apertura sullo stesso livello di dove 
ci trovavamo, dove ci entrava anche 
il furgone intero, se lo volevamo. 

Se lo volevamo? 

Lo guardammo come dei naufraghi 
guardano la sottile linea all’orizzon¬ 
te che qualcuno ha affermato esse¬ 
re la terra ferma. Se non fosse sta¬ 
to così torvo in viso e a dire la verità 
anche un poco sporco, l’avremmo 
abbracciato e baciato per la rivela¬ 
zione che ci aveva testé fatta! 

Detto fatto il tizio andò dietro una 
specie di palco e scostando dei ten¬ 
daggi pesanti di un velluto rosso ri¬ 
camato in oro, svelò un portone di 
ragguardevoli dimensioni con tanto 
di doppio catenaccio. Non era nem¬ 
meno chiuso a chiave: aprimmo e 
ci trovammo su un piazzale rag¬ 


giungibile tramite una rampa che 
arrivando avevamo visto ma che 
pensavamo portasse a dei garage 
interrati. 

La scoperta fu per noi una vera 
gioia e pur sapendo che sarebbe 
comunque stata una faticaccia il 
caricare tutto il materiale rimanente, 
almeno ci eravamo levati di mezzo 
le famigerate scale; la tortura della 
nostra mattinata. 

Intanto si era fatta Luna e il nostro 
condottiero decise che aveva fame 
e che (forse) ce l’avevamo anche 
noi. Accettammo la pausa e l’invito, 
con discrezione ma con assoluta 
fermezza nel considerare la pausa 
necessaria in modo assoluto. 

Mangiammo bene, devo dire ad 
onor del vero, in un ristorante sulla 
provinciale dove si fermavano sem¬ 
pre i camionisti: servizio celere, por¬ 
zioni abbondanti e cibo gustoso. La 
nostra defaticante mattinata fu pre¬ 
sto dimenticata e oggetto di lazzi a 
non finire sul fatto di come eravamo 
scemi a non aver capito che nessu¬ 
no si sarebbe fatto quelle scale per 
portare i bigliardi nel seminterrato! 

La megera venne con noi, non 
smise mai di fumare, lo fece anche 
mentre mangiava; era incredibile: 
masticava con la sigaretta accesa 
in un angolo della bocca! 

Andrea, che era di un pezzo il più 
giovane fra noi tre, ne era affasci¬ 
nato e sbirciava le gambe della 
signora appena gli si presentava 
l’occasione. Sia io che Michele ci 
lanciavamo segni di intesa: per noi 
era chiaro come il sole che la tizia 
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era a dir poco equivoca e il suo 
parlare sboccato la qualificava 
indiscutibilmente. Il nostro titola¬ 
re invece era a suo perfetto agio 
e oserei dire che la corteggiava in 
qualche momento, se la cosa non 
mi fosse sembrata di pessimo gu¬ 
sto. 

Comunque il pranzo finì in bellez¬ 
za con caffè e amaro doppio, il tut¬ 
to signorilmente offerto dal nostro 
titolare. La megera si fece mettere 
in conto anche due pacchetti di si¬ 
garette dichiarando che: -“Poi fac¬ 
ciamo i conti”. Il nostro eroe pagò 
tutto e stette zitto, forse sperando 
di recuperare altrimenti le spese 
della sua magnificenza, lascio im¬ 
maginare a voi come. 

Non potrei giurare che la cosa gli 
riuscisse, ma quello che è certo è 
che sparirono entrambi “in ufficio” 
e riapparvero solo a cose fatte, 
cioè a furgoni caricati e noi impa¬ 
zienti di partire che si erano fatte 
quasi le cinque di sera. 

Nell’attesa esplorammo quel¬ 
lo strano locale scoprendo delle 
stanze attigue ben arredate con 
divani e con tavoli da gioco. Arri¬ 
vammo poi in una stanza ampia 
dove c’erano un sacco di sedie 
imbottite con velluto verde, spec¬ 
chi alle pareti ma nessun tavolo o 
altro arredo che potesse rivelare a 
quale utilizzo essa era adibita. 

Il grande lampadario che avrà 
avuto diametro di due metri, dal 
quale pendevano innumerevoli cri¬ 
stalli (non me ne intendo e non sa¬ 
prei se fossero preziosi o semplici 


riproduzioni di plastica), era appe¬ 
so al soffito al centro della sale. Su 
tutto il pavimento una moquette 
rossa, anzi amaranto. 

Michele mi indicò lo spazio vuoto 
sotto il lampadario e disse che era 
chiaro che li c’era stato un tavolo e 
mi mostrò i segni delle gambe del¬ 
lo stesso sulla moquette. Concor¬ 
dammo che era un tavolo da rou¬ 
lotte; forse non era vero, ma così 
voleva la nostra fantasia. 

Quando il titolare della Game 
Star, Tiziano, si rifece vivo era or¬ 
mai buio. Aveva un’aria soddisfat¬ 
ta, come quando in certe rare gior¬ 
nate ti va tutto per il verso giusto. 
Noi al contrario eravamo esausti, 
affamati e vogliosi di andarcene a 
fare la doccia. 

Partimmo quindi io e il titolare su 
uno dei due furgoni, Andrea e Mi¬ 
chele alla guida sull’altro. Arrivam¬ 
mo che erano quasi le sette e si 
doveva scaricare. Altra faticaccia, 
altre imprecazioni e altra scheg¬ 
giatura di una delle piastre, que¬ 
sta volta in maniera seria, tanto da 
renderla praticamente inservibile, 
almeno questo disse il nostro capo 
quando si rifece vivo. Mica era sta¬ 
to li ad aiutarci a scaricare, ci man¬ 
cherebbe! Si arrabbiò e molto, poi 
si rese conto che se avesse detto 
ancora una sola parola la piastra 
che stavamo scaricando in quel 
momento sarebbe finita sui suoi 
piedi. Fece un passo indietro, nem¬ 
meno mi avesse letto nel pensiero 
e se ne andò brontolando. Quella 
sera arrivai all’albergo che erano 
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quasi le dieci, ero stanco morto e 
per la cena era tardi. Mi buttai sot¬ 
to la doccia e ci stetti finché l’ac¬ 
qua cominciò a venire fredda, poi 
mi addormentai di botto appena 
toccato il cuscino. 

Il giorno dopo mi sentivo come se 
fossi saltato giù da un treno in cor¬ 
sa e rotolato trecento metri giù per 
la scarpata: letteralmente a pezzi. 
In laboratorio constatai che Miche¬ 
le e Andrea non stavano meglio di 
me e stavano concertando il modo 
di rifiutarsi in futuro di fare quelle 
sfacchinate. A me poco importava 
ormai: ero qualsi alla fine della ter¬ 
za settimana e fra qualche giorno 
si sarebbe compiuto il mio destino, 
basta bigliardi! Pensai ma mi sba¬ 
gliavo dalla grossa. Infatti anche 
alla Automatik si noleggiavano e 
vendevano bigliardi, ma io non lo 
sapevo ancora... 

Con il senno di poi mi viene spon¬ 
taneo biasimarmi per aver accet¬ 
tato qualsiasi imposizione relativa 
al lavoro. Avevo troppa voglia di 
cambiare, di pavoneggiarmi con il 
titolo di “tecnico elettronico”, di di¬ 
mostrare con potevo fare qualche 
lavoro intellettuale invece che star¬ 
mene a spazzare il magazzino del 
supermercato. Oggigiorno imparo 
dai giovani che non vale la pena 
affannarsi tanto: basta aspettare 
rifiutando qualsiasi offerta di la¬ 
voro che non ci sembri adeguata. 
Tanto, pagano i genitori... 

Comunque imparai abbastanza 
cose in quel breve spazio di tre 
settimane passate alla Game Star 


e non solo cose tecniche, come si 
è visto. 

La prima volta fuori casa per così 
tanto tempo, in un ambiente nuo¬ 
vo dove non conoscevo nessuno. 
Non è nulla, lo so, ma capii per la 
prima volta che si poteva fare, che 
ci si poteva anche muovere dal 
paese e guadagnare con un po’ 
di sofferenza un bricciolo di cono¬ 
scenza in più. 

Anche le delusioni, le faticacce, il 
lavoro non dovuto e lo sfruttamen¬ 
to da parte di Tiziano che si era 
trovato per un giorno un operaio in 
più e gratis, ritengo facciano parte 
del mettersi in gioco e dell’accetta- 
re le esperienze che la vita ci man¬ 
da, buone o cattive che siano. 

[Lp] 
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Come era vamo... 


La storia dei sistemi 
e degli uomini che 
hanno creato un 
mondo nuovo. 


Una Teletype o 
nella traduzione 
italiana una 
“telescrivente 


Storia dell interfaccia utente (2) 


Tastiera e stampante 


■ 


S e ci pensiamo bene, 
una cosa è rimasta più 
o meno intatta nel corso 
degli anni: la tastiera. La tastiera 
alfanumerica ha delle qualità evi¬ 
dentemente insostituibili e, salvo 
l’adeguamento tecnologico del 
caso, stiamo usando ancora un 
meccanismo di input che risale 
alla scoperta della macchina da 
scrivere. 


Tastiera e stampante messe in¬ 
sieme nello stesso dispositivo (un 
tavolino di metallo), hanno costi¬ 
tuito il primo terminale a caratteri 
preannunciando quella che sareb¬ 
be stata una evoluzione possibile: 


un colloquio riga per riga con la 
macchina mediato da un display 
elettronico. In un primo tempo l’ou¬ 
tput fornito dopo ogni riga emes¬ 
sa da tastiera, serviva unicamente 
come feedback per l’operatore che 
aveva così conferma dell’avvenu- 
ta digitazione corretta della riga di 
caratteri di input. Analogamente 
nell’output che praticamente ab¬ 
bisognava semplicemente della 
stampa di un risultato numerico o 
poco più. Una certa grafica primor¬ 
diale si poteva ottenere stampan¬ 
do su un foglio una combinazione 
di simboli e caratteri che guardati 
da lontano potevano in qualche 
misura rendere l’idea di una figura 
bidimensionale. 


Il calcolatore non gode in princi¬ 
pio di una periferica espressamen¬ 
te progettata per le sue esigenze. 
All’inizio infatti è stata la teletype 
a farla da padrona. Come spesso 
succede infatti, le nuove tecnolo¬ 
gie utilizzano in parte quello che si 
trova sul mercato in quel momen¬ 
to e la telescrivente esisteva nelle 
aziende (di solito una) ma soprat¬ 
tutto esistevano i fornitori che le 
costruivano. Immaginiamo i salti di 
gioia di codesti imprenditori che si 
videro moltiplicare le possibilità di 
vendere i loro prodotti, eventual- 
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mente un poco adattati, nel settore 
emergente del Corporate Compu¬ 
ting. 


Il terminale all-in-one video-ta¬ 
stiera ha conosciuto molteplici im¬ 
plementazioni e una discreta fortu¬ 
na. Ad esempio la nostrana Olivetti 
ne ha cavalcato il successo pro¬ 
ducendo sistemi di videoscrittura 
come le famose BCS (che since¬ 
ramente non mi sovviene di quale 
combinazione di parole sia la sigla, 
qualcosa come Business Calcola- 
tor System o magari qualcosa di 
molto più italico...). 


Lo scopo di questo articolo non è 
l’evoluzione tecnologica dell’har- 
dware, per cui non parleremo di 
come la tastiera si sia evoluta e 
abbia coinvolto tutte le possibilità 
elettro-meccaniche, chimiche, ot¬ 
tiche,... possibili ed immaginabi¬ 
li per ottenere dei tasti da pigiare 
(magari solo virtualmente). 


Dal punto di vista dell’interazio¬ 
ne uomo-macchina, la tastiera ha 
cercato di venire incontro alle mol¬ 
teplici esigenze che i nuovi sistemi 
operativi e soprattutto programmi 
applicativi si sono inventati nel cor¬ 
so del tempo. Ci ha pensato Apple 
per prima a stabilire che era ne¬ 
cessario il “tasto mela”, dato che il 
classico “Control” già peraltro pre¬ 
sente nelle tastiere industriali, non 
era sufficiente. 



I tasti funzione sono una invenzio¬ 
ne che risale all’epoca dei termina¬ 
li TTY dei mainframe. Ancora oggi 
nei file di configurazione dei vari 
Unix (ad esempio Linux) si parla di 
tasti PF1 ...PFn, che è il nome che 
dava IBM ai tasti “fuori testo” nei 
propri terminali. 


-m > 

Olivetti BCS. 

Quella mostrata 
in fotografia (la 
macchina, non 
la ragazza!) 
è in realtà una 
versione molto 


Una evoluzione in linea con que¬ 
sto è stata la comparsa di tasti le¬ 
gati a specifici programmi e più in 
generale ai tasti programmabili, 
cioè dove l’utente può intervenire 
per associare una sequenza di co¬ 
mandi allo stato di “tasto premuto” 
rilevato dalle routine di input del 
sistema operativo in uso (normal¬ 
mente sono pre-programmati solo 
per Windows). L’idea non è co¬ 
munque nuova e già i costruttori 
dei primi home a volte la prevede¬ 
vano come features per promuo¬ 
vere l'usabilità delle proprie realiz- 


evoluta con tanto 
di doppia unità 
floppy da 8 pollici. 
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ad esempio geografi¬ 
che o semplicemente 
cartesiane. 


s 

La tastiera del 
terminale 3270 
della IBM. I tasti 
funzione PFxx sono 
quelli in doppia fila 
sulla sinistra. 

I _ J 


zazioni. 

La tastiera, oltre a diventare più 
tecnologica (senza fili ad esem¬ 
pio), ha provato ad integrare altre 
periferiche di input: il mouse prima 
di tutto. Si tratta di poco più che 
esperimenti, peraltro non nuovis¬ 
simi: personalmente possiedo una 
tastiera della Olivetti collegabile al 
PC attraverso infrarossi e che in¬ 
globa una piccola trackball. 

Concludendo questo excursus 
sulla periferica di input per eccel¬ 
lenza, possiamo senz’altro affer¬ 
mare che la tastiera ha attraver¬ 
sato tutta l’epopea della conquista 
dell’informatica arrivando inden¬ 
ne, anzi ringiovanita, al traguardo 
dell’era di Internet. 


Ricordo a questo pro¬ 
posito una geniale ap¬ 
plicazione di un plotter 
HP collegato all’HP85, 
che permetteva anche 
l’input. Funzionava più 
o meno così: si mette¬ 
va il grafico con la cu rea da rileva¬ 
re sul piano del plotter e si faceva 
partire il programma che rilevava 
l’input. A questo punto era l’abilità 
dell’operatore nello spostare il pen¬ 
nino per posizionarlo esattamente 
sulla curva operando con i tasti di 
movimento manuale cui la perife¬ 
rica era dotata. Ad ogni punto un 
“invio” indicava al computer di re¬ 
gistrare la posizione del pennino, 
cioè le coordinate cartesiane del 
plot della curva da rilevare. Que¬ 
sta applicazione era resa possibile 
per il fatto che l’interfaccia di colle¬ 
gamento PC-Plotter, era la HP-IB, 
una specie di seriale a bus bidire¬ 
zionale. 



Il mouse 


L’avvento del mouse ha segna¬ 
to uno snodo epocale nella storia 
delle interfacce utente. Non è che 
questo dispositivo di input sia sor¬ 
to dal deserto di idee precedente, 
anzi! Più o meno genialmente altri 
dispositivi di input sono stati pro¬ 
gettati e inseriti in mercati verticali, 
ad esempio nella grafica tecnica, 
con puntatori più o meno precisi 
per la rilevazione delle coordinate 


Il mouse stesso ha vissuto diver¬ 
se fasi e adattamenti in relazione 
al peso specifico di questa metodo 
di interazione rispetto all’interfac¬ 
cia utente studiata per un applica¬ 
tivo o più in generale per il sistema 
operativo della macchina. 

Pallina rotolante, rilevatori ottici, 
altre diavolerie (fino al laser), han¬ 
no visto la loro applicazione più o 
meno riuscita al mouse, per non 
parlare degli innumerevoli eserci¬ 
zi di design, tutti fatti passare per 
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“ultimate”, che avevano lo scopo 
dichiarato di rendere confortevole 
l’uso di questo strumento. 

Contrariamente a quanto molti 
credono, il mouse sbarca nei per¬ 
sonal computer quando ancora 
l’interfaccia grafica non era una 
realtà. Fra il terminale a caratteri 
e Windows (tanto per capirci), c’è 
una “terra di nessuno” nella quale 
sul video si sono accomodate fine¬ 
stre delimitare da simboli semigra¬ 
fici entro le quali il mouse aveva 
ragione di esistere. 


Uno dei primi personal a consen¬ 
tire l’uso del mouse è stato il vene¬ 
rabile Apple I le/l le che fece propria 
la periferica studiata per la nuova 
macchina di Apple, cioè il Mac. 
I PC propriamente detti, cioè le 
macchine IBM compatibili o DOS 
Machine, hanno anch’esse tentato 
di ricavare vantaggio da quella pic¬ 
cola appendice rotolante che tutto 
sommato costava poco e rendeva 
il sistema più moderno. 
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primi am¬ 
bienti che 
hanno 
pensato 
all’uso del 
mouse 
come utile 
strumento 
di intera¬ 
zione con 
l’utente. 

Deskview 
è un 

esempio di questa tendenza, ma 
anche programmi nativi perii siste¬ 
ma operativo di Microsoft ne han¬ 
no cavalcato l’onda. Uno che mi 
viene in mente, perché l’ho usato 
parecchio, è il Turbo Pascal della 
Borland che nelle sue release più 
avanzate (ad esempio la 7), ha fat¬ 
to un uso sistematico del concetto 
di punta e clicca. 

[Tn] 


[Sopra] 

La versione Apple 
del mouse per il suo 
Mac: un solo tasto 
e una ergonomicità 
che oggi sarebbe 
inaccettabile. 

[Sotto] 

lo Smaky Mouse, 
inventato al 
Politecnico di 
Losanna; a fianco 
una versione del 
computer Smaky 
con il relativo 


Sono stati i sistemi alternativi al 
DOS o estensioni dello stesso, i 


mouse collegato. 
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War 


seguente: -”Se i buoni cervelli im¬ 
pegnati allo sviluppo del softwa¬ 
re smettessero di occuparsi della 
guerra compagnia contro compa¬ 
gnia, avremmo ora un software 
molto ma molto più avanzato ri¬ 
spetto a quello che possiamo uti¬ 
lizzare ora”. 

Una tesi interessante e lapalis¬ 
siana, oserei dire. E’ ben evidente 
infatti che se tutti, ma proprio tutti, 
fossero impegnati a sviluppare un 
unico sistema operativo e un’unico 
software gestionale, office, etc..., 
la massa critica “grigia”, non po¬ 
trebbe che generare un compen¬ 
dio più avanzato di quanto usiamo 
giornalmente. E’ anche vero, per 
essere obiettivi, che lo sviluppo di 
certi comparti (penso alla interfac¬ 
cia utente piuttosto che alle pre¬ 
stazioni grafiche) sono state rese 
possibili dai massicci investimen¬ 
ti proprietari. E, voi mi insegnate, 
una azienda investe se ha (o ha 
speranza di avere) un ritorno eco¬ 
nomico dal prodotto che sviluppa. 

Se ci si ferma a pensare a quanti 
software ci sono in giro che fanno 
grossomodo la stessa funzione, ci 
si rende conto che John ha azzec¬ 
cato il succo della faccenda. Non 
stimao pensando a Linux verso 
Windows o a MSOffice verso Ope- 
nOffice o ancora SQLServer verso 
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Le monografie 
vecchie e nuove che 
rappresentano una 
preziosa risorsa per 
chi ama il mondo 
dei computer in 
generale. 
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KEITH CURTIS 

I ncomincia con questa citazio¬ 
ne (del 2004) di John McCar- 
thy, uno dei padri indiscussi 
della disciplina che va sotto il nome 
di Intelligenza Artificiale: 

“Some people think much faster 
computers are required for Arti fi¬ 
dai Intelligence, as well as new 
ideas. My own opinion is that thè 
computers of 30 years ago were 
fast enough ifonly we knew how to 
program them. ” 

Significa terra-terra che il software 
è la vera macchina e che Thardwa- 
re è solo un supporto, purtroppo 
sempre sotto-utilizzato rispetto alle 
potenzialità che il buon software 
potrebbe abilitare (e nobilitare) in 
esso. 

La tesi che sostiene l’autore è la 



































Oracle, stiamo pensando alla 
miriade di applicazioni svi¬ 
luppate da “solisti” e che si 
sovrappongono una sull’altra 
spesso con differenze mini¬ 
me. 
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Tempo fa stavo cercando un 
software per il time-tracking, 
che per chi non lo sapesse 
è un qualcosa che aiuta a te¬ 
nere traccia di quanto tempo 
si passa su un progetto. Pur 
limitando la ricerca al sistem 
operativo MAC OSX, l’unico 
che uso per lavoro, mi sono trova¬ 
to difronte a qualche decina di pos¬ 
sibilità fra le quali scegliere. Bene, 
analizzandone qualcuna le diffe¬ 
renze erano veramente minimali, 
soprattutto limitandosi a confronta¬ 
re le funzionalità piuttosto che l’in¬ 
terfaccia, i colori, l’amichevolezza, 
etc... 

Il volume di 300 pagine, pubbli¬ 
cato secondo gli standard della 
filosofia Creative Commons, è un 
buon testo per capire lo stato 
dell’arte del software nei vari 
comparti e la storia e retro¬ 
scena che ne ha caratteriz¬ 
zato lo sviluppo. 


E’anche vero che, come si dice “il 
modo è bello perché è vario” e alla 
resa dei fatti l’attuale situazione 
che vede molti concorrenti e mol¬ 
ti prodotti che fanno più o meno la 
stessa funzione, è comunque un 
“buon mondo”, basta pensare a 
dove eravamo appena venti anni 
orsono (cioè al DOS di Microsoft) 
per convincersene. 

[Sn] 


Una delle immagini 
finali del volume; 
riassume bene l’idea 
di evoluzione del 
software rispetto alle 
potenzialità finora non 
espresse. 

(Sotto) In questa 
raccolta di simboli 
(tratta dal volume), 
sono rappresentate 
le features (alcune 
palesemente 
provocatorie) che 
potremmo avere ma 
che non abbiamo 
ancora. 


A 

A 

A 

/Ù\ 

ACIIVL NANO- 
DLVICtS 

ANI IMA! ILK 

AUIONOMOUS 

OtVICE 

CIIAOIIC SYSTEM 





yOy 

A 

/é\ 

A 

DIAMONDOID 

SURFACFS 

GROUP IN 1 ELLECI 

IACK OF INTFRNFT 
CONNFCTIVITY 

MAC ROSC ALL 
OUANIUM SYSTLM 





A 

A 

A 

/Sk 

MOTIVATION 

HA7ARD 

NANOPARTICI F 
HA7ARD 

NONSTANDARD 
SPACF1 IME 

SFI F-FVOIVING 
SYSTFM 





A 

A 


A 

A 

SFI F-RFPI ICATING 
OFVICF 

SFA 
SI KANC 

ULL 

•ELLIS 

UBIQUIIOUS 
SURVL IL LANCE 

LXISILN 1IAL 
THRFAT 



À 

MFMFTIC HA7ARD 


SFLF-IM PROVINO 
SOFTWARE 


Conclusione. 

E’ molto intrigante l’idea 
di un mondo possibile che 
avrebbe potuto svilupparsi se 
l’industria informatica avesse 
seguito strade diverse rispet¬ 
to a quella protezionistica (il 
male in fondo deriva da quel¬ 
la prima decisione). 
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Retro Riviste 


Super Apple 


La rassegna 
critica dell’editoria 
specializzata dai 
primi anni ‘80 ad 
oggi 
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Editore: 
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N egli anni dal ‘84 al ‘90 
circa abbiamo assistito 
al fenomeno dell’ home 
computer e con esso alla corri¬ 
spondente nascita di numerose 
testate mono-marca se non addi¬ 
rittura mono-modello. 


Piccoli calcolatori personali, po¬ 
chissimo equipaggiati in termini 
di memoria e unità magnetiche, 
venivano spacciati per super mac¬ 
chine in grado di svolgere com¬ 
piti non solo domestici domestici 
ma soprattutto giochi e agende 
personali. Non mancava qualche 
speranzoso operatore pubblicita¬ 
rio che cercava di vendere il tutto 
alla massaia di turno con la scusa 
delle ricette, della lista della spesa 
e del calcolo del detersivo perii la¬ 


vaggio settimanale. 

Ca posti piti di questa invasione 
furono i computer della Com¬ 
modore (Vie, 64), della Sinclair 
(ZX81, Spectrum) e Apple (Ile, 
Ile). Ma numerose altre case co¬ 
struttrici misero sul mercato i loro 
modelli cercando di ritagliarsi una 
loro fetta di mercato. Molto inte¬ 
ressante sarà il fenomeno degli 
“MSX”, cioè macchine costruite 
da produttori diversi ma compa¬ 
tibili a livello di codice. 

Il boom degli “home” fu una 
vera manna per i produttori: alta 
percentuale di ricarico, nessu¬ 
na assistenza software e scarsa 
assistenza hardware; insomma 
un autentico paradiso anche se 
la sua durata è stata limitata a 
meno di un decennio. La manna 
finì nel momento in cui entrarono 
i cloni dei pc a prezzo “umano”. 
Si pensi ad esempio che nel 1987 
l’Olivetti M24 costava la bellezza 
di 7 milioni e l’originale IBM più di 
10! Era logico che l’utente non di¬ 
scendente dal pascià di Persia, si 
accontentasse delle macchine da 
500/600 mila lire. 

Gli home nascevano con un loro 
sistema operativo più o meno so¬ 
fisticato ma con una dotazione di 
software scarsissima. Ciascuno 
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però poteva creare i propri pro- 
grammini grazie aH’onnipresente 
interprete Basic. 

Ecco quindi l’utilità delle riviste 
super-specializzate, ricche di lista¬ 
ti e, qualche volta con un floppy o 
una cassetta. Chi acquistava un 
certo modello era poi praticamen¬ 
te obbligato a comprare la rivista 
di riferimento, per il software senza 
dubbio, ma anche semplicemente 
per sentirsi meno solo. A riprova 
di queste affermazione la nascita 
coeva di numerosissimi “Computer 
Club”, spesso editori di “fanzine” 
dalla bassa tiratura e dalla periodi¬ 
cità del tutto casuale, ma dai con¬ 
tenuti quasi sempre interessanti. 

“Super Apple” è una rivista mono¬ 
marca, interamente dedicata al sof¬ 
tware per i sistemi Apple, edita dal 
gruppo editoriale Jackson. Lo stuff 
editoriale è interamente italiano e 
questo è un segnale importante: 
l’editore non ha seguito la più facile 
strada della “rivista tradotta”. 


Vale a questo punto la pena che 
io spenda due parole riguardo pro¬ 
prio all’editore. Il gruppo editoriale 
Jackson mi ha ben presto deluso: 
ha prodotto moltissimo ma quasi 
sempre prodotti “di cassetta” pron¬ 
to ad abbandonare la barca al pri¬ 
mo calo di vendite. Le traduzioni 
dei libri poi sono state a volte degli 
autentici “scapolavori”, della se¬ 
rie “lo speriamo che me la cavo”. 
Ciò’ nonostante è stato un editore 
importantissimo per la diffusione 


dell’informatica personale in Italia 
e di ciò’gli si deve dare atto. 


Evidentemente il mondo Apple di¬ 
spone di un installato nostrano di 
numerosità consistentente, tale da 
convincere qualcuno nella bontà 
dell’impresa. La diffusione Apple in 
Italia non è niente di paragonabile 
a quella degli Stati Uniti, per meri¬ 
to di una diversa scala reddituale 
(il loro potere d’acquisto è sempre 
stato di gran lunga superiore al no¬ 
stro), ma anche di una lungimiran¬ 
te politica di diffusione nelle scuole 
e università. Il marketing della Ap¬ 
ple di allora era chiarissimo: “Se lo 
studente trova il nostro computer 
nella scuola ed impara su di esso, 
poi quando sarà in azienda spinge¬ 
rà che venga adottato anche li”. 


La parte “Mac” della rivista è net¬ 
tamente divisa dalla parte “II” e 
confinata nella zona denominata 
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“SuperMac”. Il taglio è decisamen¬ 
te meno tecnico rispetto alla con¬ 
troparte dedicata ai “ piccoli” della 
serie II. Incominciano ad imporsi 
applicativi da ufficio della serie 
“office” e quindi prove di Word e 
fogli di calcolo in Excel hanno am¬ 
pio risalto. Certo che a vederle ora 
queste schermate di Excel fanno 
sorridere, ma il foglio di calcolo 
della Microsoft sul Mac è stata 
una autentica rivoluzione nel cam¬ 
po della usabilità. 

Dedicato ad “AppleWorks”, con 
l’analisi del modulo “foglio di cal¬ 
colo”, un lungo articolo nella rubri¬ 
ca “Profilo Software” nella parte 
di rivista dedicata all’Apple II. Ap¬ 
pleWorks è stato il padre di tutti i 
software “suite”, cioè delle raccol¬ 
te di programmi collaborativi che 
possono scambiarsi i dati. L’idea 
era rivoluzionaria per l’epoca ma 
il “copia-incolla” diventerà l’indi¬ 
spensabile feature di ogni integra¬ 
to degno di questo nome (come 
potremmo farne senza?). 

Enrico Colombini si dimostra un 
vero esperto della mela e un buon 


terzo dell’intera rivista nasce dal¬ 
la sua penna (il che a volte lascia 
abbastanza sconcertati: possibile 
non ci siano buoni giornalisti tecni¬ 
ci in grado di scrivere sui prodotti 
della Apple Computer?). Si va dal 
corso di Assembly per il 6502 alla 
presentazione di “Melopoli”, il Mo¬ 
nopoli programmato in Basic dallo 
stesso autore dell’articolo. 

Non manca l’articolo divulgativo: 
“Banche dati”. Il modem comincia 
a suscitare interesse; nascono le 
prime “banche dati”, anche se per 
la nascita delle fenomeno “BBS” 
c’è ancora tempo. 


Super Apple Programmi 


Come tutte le riviste anche Super 
Apple arricchisce i propri servizi 
verso il lettore con una ricca rac¬ 
colta mensile di programmi pronti 
per essere digitati e, quindi, ese¬ 
guiti sul proprio Apple Ile (o altro 
modello compatibile). 

Simpaticamente il sommario 
viene chiamato “CATALOG” che 
è appunto il comando del DOS 
(quello Apple, non quello della Mi¬ 
crosoft per PC J ). Vi troviamo la 
solita lista che spazia dai giochi- 
ni tipo “l’impiccato” alle utilità tipo 
“tastiera magica”. 

Non mancano i gestionali: “ar¬ 
chivio Apple” ad esempio è un 
programma di circa 300 righe che 
permette di tenere un vero e pro¬ 
prio archivio del proprio materiale 
informatico. Niente a che fare con 
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dBase o altro più famoso, natural¬ 
mente. Semplicemente un piccolo 
programmino dal quale trarre utili 
spunti di programmazione. 


Negli anni ’80 le riviste di infor¬ 
matica erano abbastanza poco 
approfondite, mancava Internet e 
la letteratura tecnica scarseggia¬ 
va alquanto. I sorgenti erano una 
fonte insostituibile di trucchi e tec¬ 
niche di programmazione introva¬ 
bili altrove; la semplicità del Basic 
faceva il resto. 


Il sorgente più tosto contenuto 
in questo fascicolo è sicuramente 
quello chiamato “Window” che ha 
come scopo dimostrare l’utilizzo 
di due funzioni davvero incredibili 
che permettono di creare delle fi¬ 
nestre un po’ come sul Mac Intosh 
(Windows non è nemmeno nella 
mente di Bill Gates). Le due funzio¬ 
ni si realizzano semplicemente con 
due CALL e le loro istruzioni sono, 
manco a dirlo, farcite di PEEK e 
POKE che salvano e ripristinano 
porzioni di video. 

E il mouse? Beh, state preten¬ 
dendo un po’ troppo. Il Mouse per 
Apple Ile esiste ma l’uso è tutt’altro 
che banale. Credo che sarà neces¬ 
sario attendere il ProDOS per ve¬ 
dere all’opera qualcosa che asso- 
migli ad una interfaccia a finestre 
con tanto di gestione dal mouse. 


Conclusione 


La strada dell’informatica è irta di 
molti pericoli per i sistemi della 
mela e non solo dovuti alla com¬ 
parsa dei cloni IBM. Scelte di mar¬ 
keting a dir poco discutibili, disaffe¬ 
zione degli utenti e migrazione 
verso il meno invitante ma più pra¬ 
tico “mondo IBM”, lasceranno la 
Apple Computer con poco più di un 
pugno di mosche in mano. A di¬ 
spetto delle funzionalità limitate dei 
primi PC (intendendo con la sigla 
“PC” le macchine equipaggiate con 
i processori Intel ed architettura 
IBM) come ad esempio nella grafi¬ 
ca per non parlare del suono, pur 
tuttavia la strada è inesorabilmente 
tracciata e saranno le “DOS Ma¬ 
chine” a dominare il mercato di qui 
a pochi anni. 

[Sn] 


La copertina del 
fascicoletto allegato 
“Super Apple 
Programmi”. 


luper Apple programmi U. p-" A ; pl-> prrf 
Super Apple programmi Super 
Ipple programmi Super Apple program 
ni Super Apple programmi Super Apple 
programmi pw Apple programmi 8\i 
per Apple programmi Super Apple progr 
immi Super Apple programmi Super Ap 
)le programmi Super Apple programmi 
Kiper Apple programmi 8uper Apple prc 
grammi Super Apple programmi Super 
Apple programmi Super Apple program 
ni Super Apple programmi Super Apple 
grammi 8uper Apple programmi S\j 
>er Apple programmi Super Apple progi 
immi Super- ApphJ$28^ammi Super Ap 
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TAMC 


Algoritmi di SORT (parte 5) 


Teoria e 
Applicazioni 
delle Macchine 
Calcolatrici: la 
matematica e 
l’informatica, 
le formule e 
gli algoritmi, la 
completezza e la 
computabilità, le 
strutture dati e tutto 
quello che sta alla 
base dell’informatica. 


Heap Sort 

L ’Heapsort è un algoritmo di 
ordinamento che si basa 
su una struttura computa¬ 
zionale chiamata heap. Dal pun¬ 
to di vista teorico un heap è una 
struttura dati che riceve dei valori e 
li mantiene ordinati facendo “emer¬ 
gere” come primo elemento quello 
che ha una particolare caratteristi¬ 
ca (ad esempio la priorità) più alta 
degli altri elementi. 

Una maniera pratica di realizzare 
questo è disporre di un vettore nel 
quale gli elementi sono mantenuti 
ordinati da un qualche algoritmo 
che già conosciamo, ad esempio 
un Quicksort, cosa che ovviamen¬ 
te non aggiunge nulla di nuovo 
all’efficienza per ottenere un ordi¬ 
namento di elementi, oltre al fatto 
che realizzare una struttura heap 
procedendo all’ordinamento com¬ 
pleto di un vettore ogni volta che 
viene inserito un elemento, è a dir 
poco inefficiente. Pertanto sono 
stati studiati metodi migliori per re¬ 
alizzare ciò. 

Una prima osservazione è che un 
heap può essere rappresentato da 
un albero binario. Vediamo in figu¬ 
ra 1 come sarebbe costruito l’albe¬ 
ro per il vettore di esempio: 


[3, 5, 7, 1, 4, 6, 2] 

Si vede come questa rappresen¬ 
tazione permetta di sapere qual’è 
l’elemento maggiore dell’insieme, 
visto che è la radice stessa dell’al¬ 
bero. 

Estratto il primo elemento (il valo¬ 
re 7 nel caso di esempio), l’albero 
va ricostruito (Figura 2). 

Notate due cose che sono evi¬ 
denziate dalle figure: l’albero non è 
ordinato ma semplicemente si as¬ 
sicura che la radice di un nodo sia 
maggiore dei suoi figli e seconda 
osservazione: l’albero è completo, 
cioè i nodi finali (foglie) sono tutti 
portati allo stesso livello di profon¬ 
dità. 

Questa seconda caratteristica (la 
completezza) non è strettamen¬ 
te essenziale se si volesse usa¬ 
re l’albero come struttura dati per 

10 heap. In realtà l’albero binario 
completo ha un vantaggio compu¬ 
tazionale rispetto allo stesso albe¬ 
ro non completo: può essere rap¬ 
presentato in memoria come una 
matrice. 

Nello studio delle strutture dati 
gli alberi sono costruiti solitamen¬ 
te con due elementi: i nodi e i link. 

11 nodo contiene il valore in esso 
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posizionato e poi n link (due 
nel caso di albero binario) che 
puntano ai nodi figli. 

Il problema di questa strut¬ 
tura computazionale è che la 
ricostruzione dell’albero nel 
caso di estrazione di un nodo, 
diventa onerosa; in pratica an¬ 
drebbe ricostruito l’intero albe¬ 
ro. Ovviamente se vogliamo 
guadagnare qualche cosa nei 
tempi di ordinamento dobbiamo 
sfruttare qualcos’altro e questo al¬ 
tro è appunto la rappresentazione 
dello heap come vettore di n ele¬ 
menti (n è anche la dimensione del 
vettore da ordinare). 

Se il nodo radice occupa la pri¬ 
ma posizione del vettore, i suoi figli 
sono rispettivamente nella secon¬ 
da e terza posizione: 

[7, 5, 6,...] 

i successori del nodo [5] vengono 
inseriti in quarta e quinta posizio¬ 
ne: 

[7, 5, 6, 3, 1,...] 

insomma il successore sinistro 
del nodo i si trova nella posizione 
2i dello heap, mentre il successore 
sinistro si trova in 2i+1. 

La regola è quindi molto sem¬ 
plice e così pure dato il nodo 
in posizione i, sappiamo che il 
suo genitore si trova in i/2. 

Trattare un albero descritto in 
questa maniera è, lo si capi¬ 
sce perfettamente, un grande 
vantaggio in termini compu¬ 
tazionali ed è proprio qui che 
heapsort guadagna. 
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Nel listato pubblicato nella pagina 
seguente, vediamo la semplicità 
dell’algoritmo. 

Il programma è ridotto a due loop 
lineari; il primo inserisce gli elemen¬ 
ti nello heap e il secondo li estrae. 


Figura 1. 

L'albero binario 
iniziale costruito con 
gli elementi del vettore 
da ordinare. 


1 


w 


Le due funzioni che sottostanno 
alle due attività le abbimao chia¬ 
mate putheapf) e getheapQ ri¬ 
spettivamente. 


L’aggiunta di un nodo allo heap 
consiste nel far occupare al nuovo 
elemento la prima posizione libe¬ 
ra e poi “migrarlo” eventualmente 
verso l’alto del vettore confrontan¬ 
dolo con il suo genitore ed even¬ 
tualmente scambiandolo con esso. 
Si tratta quindi di un semplice con¬ 
fronto con log(n) elementi che va 


Figura 2. 

La prima estrazione 
toglie l'elemento più 
alto dallo heap e 
riorganizza l'albero. 


\ _ J 
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Program sortheap; 
var 

A, B : array[1..7] of integer; 
i: integer; 

procedure putheap(i: integer); 
var 

k, P : integer; 
temp : integer; 

begin 
k := i; 

p := k div 2; 

B[k] := A[k]; 

while (k > 1) and (B[k] > B[p]) do begin 
temp := B[p]; 

B[p] := B[k]; 

B[k] := temp; 
k := p; 
end; 

writeln(B[l], ‘ B[2], ‘ B[3], ‘ % B[4], ‘ % B[5], ‘ % B[6], 
end; 

function getheap(n: integer): integer; 
var k, p : integer; 
temp : integer; 

begin 

getheap := B[l]; 

B[l] := B[n]; 

B[n] := 0; 
k := 1; 


eseguito per gli n elementi del 
vettore. 

L’operazione non bilancia l’albe¬ 
ro binario in senso stretto, cioè è 
possibile che un figlio risulti mag¬ 
giore del rispettivo padre per ef¬ 
fetto dell’inserimento di un nodo 
che ha sostituito il genitore. 

Per quanto un albero binario 
bilanciato sarebbe migliore per 
procedere all’ordinamento, l’ope¬ 
razione viene rimandata al mo¬ 
mento dell’estrazione del nodo 
radice che è per destinazione 
l’elemento più grande dell’insie¬ 
me da ordinare. Si noti che l’ope¬ 
razione di parziale ordinamento 
che viene messa in atto dalla 
funzione getheap, viene esegui¬ 
ta su un albero ridotto di una di¬ 
mensione in profondità (ha perso 
la radice), il che rende ancora più 
efficiente l’algoritmo. 

Come nel caso del Mergesort, 
anche l’Heap sort ha un com¬ 
portamento costante rispetto alla 
complessità di esecuzione nei 
casi che si possono presentare. 
Infatti l’ordine è 0(nlog 2 n) per 
tutti i casi. 

Abbiamo così esaminato due 
algoritmi (Heapsort e Mergesort) 
che si dimostrano comparabili dal 
punto di vista della complessità, 
e danno tempi di esecuzione mi¬ 
gliori rispetto agli algoritmi esa¬ 
minati in precedenza, soprattutto 
nel caso peggiore. Possiamo in¬ 
serire fra di essi anche Quicksort 
che è penalizzato solo dai casi 
sfortunati (è dell’ordine di n 2 ). 


“,B[7]); 


while (k < n) and ( (B[k] < B[2*k]) or (B[k] < B[2*k + 1])) do begin 
if (B[2*k] > B[2*k + 1]) then begin 
temp := B[k]; 

B[k] := B[2*k]; 

B[2*k] := temp; 
k := 2*k; 
end 

else begin 
temp := B[k]; 

B[k] := B[2*k + 1]; 

B[2*k + 11 := temp; 
k := 2*k + 1; 
end; 
end; 

writeln(B[l], ‘ B[2], ‘ % B[3], ‘ % B[4], ‘ % B[5], ‘ % B[6], ‘ % B[7]); 

end; 

begin 
A[l] := 3; 

A[2] := 5; 

A[3] := 7; 

A[4] := 1; 

A[5] := 4; 

A[6] := 6; 

A[7] := 2; 

writeln(‘Heap Sort’); 
writeln; 
writeln; 

writeln(A[l], ‘ A[2], ‘ A[3], ‘ A[4], ‘ A[5], ‘ A[6], 
writeln (‘================’); 

for i:= 1 to 7 do putheap(i); 
writeln (‘================’)5 

for i := 7 downto 1 do A[i] := getheap(i); 
writeln ('================’); 

writeln(A[l], ‘ A[2], ‘ % A[3], ‘ % A[4], ‘ % A[5], ‘ A[6], 
readln; 

end. 
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La domanda è: -"Quale dobbiamo 
scegliere?” 

Ovviamente dipende dalle cir¬ 
costanze; infatti non è detto che 
non si conosca proprio nulla del 
sistema da ordinare. Ad esempio 
può essere noto che il vettore è 
parzialmente ordinato o magari or¬ 
dinato quasi del tutto e in questo 
caso la scelta Quicksort è migliore 
dei concorrenti. Questo caso suc¬ 
cede quando si debba inserire un 
insieme di numeri piccolo rispetto 
all’insieme originale già ordinato. 
La strategia è quella di aggiun¬ 
gere semplicemente gli elementi 
nuovi in testa o in coda all’insieme 
originale e poi lanciare su di esso 
Quicksort che troverà il vettore già 
ordinato o quasi. 

Mergesort e Heapsort hanno uno 
svantaggio rispetto a Quicksort: la 
dimensione di memoria che occu¬ 
pano è il doppio dell’insieme da or¬ 
dinare. Questo perché richiedono 
delle strutture dati di appoggio che 
hanno dimensione N, se N è la di¬ 
mensione dell’insieme da ordinare. 
Peraltro se stiamo ordinando og¬ 
getti diversi da semplici numeri in¬ 
teri, mergesort potrebbe essere la 
scelta migliore perché permette la 
divisione fisica di sottoinsiemi che 
si possono anche “appoggiare” su 
un file-system (è il caso di interi re¬ 
cord all’interno di un file). 

Heapsort è una soluzione “di nic¬ 
chia”, la sua utilità si evidenzia in 
due casi: quando il linguaggio che 
usiamo non supporta la ricorsione 
o è penalizzato dall’utilizzo delle 
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chiamate rientran¬ 
ti (un esempio è il 
COBOL), oppure 
non serve specifica¬ 
tamente un ordina¬ 
mento ma una estra¬ 
zione da un insieme 
dell’elemento che ha 
una certa proprietà 
maggiore degli altri 
elementi. Questo è 
proprio il significato 
di uno heap: accet¬ 
tare valori e restituire 
sempre l’elemento 
maggiore senza ope¬ 
rare un vero ordina¬ 
mento dell’insieme 
residuo. 


Heap Sort 


3 5 7 14 6 2 


3 0 0 0 0 0 0 
5 3 0 0 0 0 0 
7 3 5 0 0 0 0 
7 3 5 1 0 0 0 
7 4 5 1 3 0 0 
7 4 6 1 3 5 0 



r -|-^ 

Figura 3. 

L'output del 
programma sul vettore 
di esempio.. 


Archiviato Heapsort stiamo vol¬ 
gendo verso la fine dell’esame dei 
sistemi di ordinamento “fondamen¬ 
tali” che sono studiati in algoritmi¬ 
ca. La prossima volta vedremo un 
algoritmo che ha una complessità 
N anche nei casi peggiori: pratica- 
mente un sogno... 


[Sm] 
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Retro Linguaggi 



| LISP(parteZ) 


La storia 
dell’informatica è 
stata anche la storia 
dei linguaggi di 
programmazione. 



dell’intera programmazione LISP. 
Queste si chiamano CAR e CDR 
(pronuncia “car” e “cudar”). La pri¬ 
ma restituisce il primo elemento 
della lista passata come argomen¬ 
to, la seconda restituisce la lista 
“decapitata” del primo elemento. 


Funzioni e liste 


D unque il LISP è un lin¬ 
guaggio orientato alla 
manipolazione delle li¬ 
ste, fino a qui lo abbiamo capito 
tutti. Ora da questa dichiarazione 
di intenti ci si aspetterebbe una 
lista infinita di funzioni che mani¬ 
polano liste e invece, sorpresa: le 
funzioni sono sorprendente poche. 
Come mai? 

La risposta è che qualsiasi funzio¬ 
ne necessiti basta costruirsela! Bel 
proposito, per un programmatore 
moderno! Già, questi programma- 
tori “moderni” che hanno la pappa 
precotta già belle e confezionata e 
al massimo ereditano una proprie¬ 
tà da una classe e ne definizcono 
due metodi in croce. Non che ci 
sia niente di male in questo, anzi! 
Solo che non è proprio in sintonia 
rispetto a come mi pongo difronte 
ad un algoritmo da implementare. 

Bando alle ciance e veniamo ad 
esaminare le due funzioni cardine 


Esempio: 

(car ‘(a b c)) -> a 

(cdr ‘(a b c)) -> (b c) 

semplice ed elegante (come sono 
sempre le cose semplici). 

Se ci pensate con queste due fun¬ 
zioni se ne costruisce un bel po’... 

Già, ma come si fa a definire una 
nuova funzione LISP? C’è a que¬ 
sto scopo una funzione speciale il 
cui compito è appunto costruire al¬ 
tre funzioni. Ecco la sua sintassi: 

(defun name (parameter*) 
body-form*) 

Esempio: 

(defun somma (a b) (add ab)) 

Abbiamo definito una nuova fun¬ 
zione che si chiama “somma” e 
che si aspetta due parametri, qui 
indicati formalmente con le due 
lettere a e b. Il “corpo” della funzio¬ 
ne è la sequenza di altre funzioni 
da chiamare e il risultato è esatta- 
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mente del tipo restituito dall’ultima 
funzione chiamata che esce dallo 
stack. 

Definiamo ora una funzione che 
restituisce il secondo elemento di 
una lista. 

(defun secondo (lista) 

(car (cdr lista)) 

) 

Cioè: per ottenere il secondo ele¬ 
mento della lista “lista” basta pren¬ 
dere il primo elemento della lista 
decapitata del primo elemento. 


vedere e non così chiaro da legge¬ 
re. Gusti sono gusti... 


La valutazione del risultato 


Come è ben noto a tutti (credo), 
quando si scrive codice si scrivono 
anche errori, effettivi o potenziali, 
cioè i famosi bug. 

Ad esempio se applichiamo la 
funzione “secondo” ad una lista 
che ha un solo elemento cosa suc¬ 
cede? 


Per esercizio provatevi a definire 
la funzione che restituisce il terzo 
elemento della lista. Non è com¬ 
plicato, ma se non ci riuscite ecco 
qua la soluzione: 


(defun terzo (lista) 

(car (cdr (cdr lista) 


Abbiamo indentato il codice e 
portato le parentesi di chiusura su 
righe separate per chiarezza espo¬ 
sitiva. In realtà nel codice che si 
leggerebbe in giro il tutto è scritto 
“pian” senza grande importanza 
alla sintassi: 


(defun terzo (lista) 

(car (cdr (cdr lista)))) 


(secondo ‘(a)) 

da un risultato o da errore? 

Cercando di ragionare come il 
sistema durante la valutazione, 
vediamo che prima di tutto viene 
risolta la funzione (cdr lista) che 
risponde con un NIL, cioè il pun¬ 
tatore vuoto perché in una lista di 
un solo elemento non c’è nessun 
cudar! 

Poi questo risultato viene preso in 
carico dalla funzione car e la valu¬ 
tazione finale diventa: 

(car NIL) 

il cui risultato è NIL, cioè un pun¬ 
tatore vuoto. 


Come si vede dall’essempio scrit¬ 
to, la proliferazione delle parentesi 
rischia di confondere la vista. Alcuni 
dialetti accetterebbero una sintassi 
con parentesi quadra a chiusura: 


(defun terzo (lista) 

(car (cdr (cdr lista] 

ma secondo “i puristi” è brutto da 
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Definizione di nuove funzioni 


Si vuole costruire una funzione 
che data una lista ne restituisca 
un’altra formata solo dai primi due 
elementi della lista originale. 

Ecco il codice: 

(defun primi_due (lista) 

(list (car lista) 

(car (cdr lista)) 

) 

) 

Riteniamo superfluo commentare 
questo codice che dovrebbe ormai 
esservi semplice da comprende¬ 
re. 

Ora la funzione applicata ad una 
lista: 

(primi_due ‘(a b c d)) 

-> (a b) 

Come si diceva la costruzione di 
una elaborazione LISP consiste 
nella definizione di funzioni che 
alla fine portano al risultato. Ad 
esempio per costruire una fun¬ 
zione che restituisca una lista dei 
primi tre elementi di un’altra lista 
sorgente potremmo scrivere: 

(defun primi_tre (lista) 

(list (car lista) 

(car (cdr lista)) 

(car (cdr (cdr lista))) 

) 

) 

Oppure, usando le funzioni pri- 
mi_due e terzo, prima definite: 

(defun primi_tre(lista) 

(list (primi_due(lista)) 
(terzo lista) 

) 

) 

In effetti il codice appena scritto 


non restituisce esattamente il ri¬ 
sultato desiderato. 

Vediamo: 

(primi_tre ‘(a b c d e f)) 

-> ((a b) c) 

cioè non si tratta propriamente di 
una lista con i primi tre elementi 
ma di una costruzione più com¬ 
plessa: una lista formata da una 
sottolista e dal terzo elemento del¬ 
la lista sorgente. 

Per ottenere il risultato voluto do¬ 
vremmo modificare la nostra defi¬ 
nizione: 

(defun primi_tre (lista) 

(list (car (primi_due lista)) 
(car (cdr (primi_due lista))) 
(terzo lista) 

) 

) 


Nuove funzioni matematiche 


Vediamo un esempio di definizio¬ 
ne di una funzione che fa uso delle 
operazioni aritmetiche. 

Supponiamo di voler definire una 
funzione che applicata a due nu¬ 
meri restituisca il resto della di- 
vision. Chiameremo questa fun¬ 
zione RESTO, con uno slancio di 
fantasia :-) 

Dato che la funzione DIV resti¬ 
tuisce il quoziente della divisione, 
faremo uso di una funzione prede¬ 
finita built-in che si chiama INT e 
che restituisce la parte intera di un 
numero. 

Ad esempio: 

(INT 3.14) -> 3 
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quindi ad esempio: 
(DIV 10 3) -> 3.33 
(INT (DIV 10 3)) -> 3 


Questo è quello che ci serve per 
ricavare il resto, infatti scriveremo: 


(defun resto (a b) 

(sub b 

(mult a 

(int (div a b)) 

) 

) 

) 

Ora, basta provare: 

(resto 10 3) -> 1 


Il bello dei linguaggi funzionali è 
che la costruzione di nuove funzio¬ 
ni è un processo del tutto naturale 
e supportato in maniera nativa. 


utili all’elaborazione che affrontia¬ 
mo in quel momento. 


Concludiamo questa seconda 
puntata del corso ricordando che 
il LISP è il linguaggio di program¬ 
mazione interno ad Autocad, il sof¬ 
tware di disegno tecnico leader del 
mercato. 

Tale implementa¬ 
zione viene chiama- 

The Visual LISP 
Developers Bible 
2003 Edition (v2) 

By David M. Stein 

Visual LISP Development with AutoCAD 2004 

[Sm] 


ta Visual Lisp ed in 
rete si trovano nu¬ 
merose risorse ad 
esso dedicate. 





Il LISP non possiede di suo una li¬ 
breria matematica particolarmente 
sofisticata. Esistono le funzioni tra¬ 
scendenti e trigonometriche e poco 
altro, ma come abbiamo visto non 
è difficile procedere alla costruzio¬ 
ne di una propria libreria di funzioni 



BiOVDIF 

TECHNOLOGIES 

Company Products Client list Store 

LISP Generator 

Home Foahres How it worfcs Tour Excmples FAQ Pereti ese 


EXPERIENCE THE 

«4 

POWER 


■ 

LISP Generator 

Send productivity & 


precision 


eionc-?no6 


Sopra: la coper¬ 
tina del libro “The 
Visual LISP Deve- 
loper’s Guide” 

a fianco: il sito 
del prodotto “LISP 
Generator” 
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Abandoned Times 


In edicola o sul 
Web le riviste 
che parlano 
di computer, 
preferibilmente 
retro e free 


Scheda 



Titolo: 

Abandoned Times 

Sottotitolo: 
Abandoned but not 
forgotten 


Editore: 

RedAvatar 


Web: 

www. abandonia. com 


Lingua: 

Inglese 


I l retro gaming è sicuramente 
una branca notevole delle atti¬ 
vità che riguardano il recupero 
dei vecchi calcolatori e in partico¬ 
lare il loro uso. 


In effetti, se andiamo ad esami¬ 
nare per cosa sono usati eventual¬ 
mente le vecchie piattaforme di 
elaborazione, scopriremo che per 
la maggior parte dei casi si tratta 
di piattaforme adattate al gioco. 
Cioè si conserva il vecchio home 
per farci girare i vecchi titoli ludici 
ai quali siamo affezionati, mentre 
è solo marginale l’utilizzo con altri 
applicativi. 


Prezzo: 

Free 

Primo numero: 

Maggio 2009 


Se i vari programmi applicativi, 
ad esempio di produttività perso¬ 
nale come word-processor o simili, 
hanno evoluto le loro prestazioni e 
in definitiva arricchita la loro offer¬ 


ta di servizi e di efficienza per l'uti¬ 
lizzatore, nel caso del gioco non è 
affatto così scontata l’evoluzione. 
Ci possono essere cioè dei giochi 
che sono inarrivabili per giocabi- 
lità e atmosfera anche se magari 
la grafica è blocchettosa, i colori 
sono solo quattro e il 3D manca 
del tutto. 

Fra i titoli che gradualmente esco¬ 
no dai listini e dalla disponibilità 
del mercato ci sono anche migliaia 
di giochi che ogni anno vengono 
abbandonati al loro destino. La 
definizione di abandoned-game 
fa riferimento al software non più 
supportato e non più disponibile 
alla vendita per il quale chi detiene 
i diritti di sfruttamente ne ha libera¬ 
to l’uso. Pur essendo una minima 
parte rispetto alla massa di titoli, 
i giochi “liberati” costituiscono co¬ 
munque una numerosità notevole 
e un parterre interessantissimo. 

Non mancano i siti Internet curati 
da appassionati del retro-gaming 
fra i quali Abandonia (indirizo www. 
abandonia.org) che è focalizzato 
principalmente (se non in manie¬ 
ra esclusiva) verso la piattaforma 
PC. 

Recentemente gli amici del sito 
Abandonia, che fa parte del “giro” 
che regolarmente visito, hanno 
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dato vita ad una iniziativa editoria¬ 
le con nome “Abandoned Times” 
che intende essere un po’ quello 
che Jurassic News è per il retro 
computing in generale. 

L’idea di costruire delle fanzine 
ad immagine di rivista periodica 
prende sempre più piede (in realtà 
non è mai morta questa idea), an¬ 
che se poi, come sappiamo benis¬ 
simo, queste iniziative raramente 
sopravvivono a qualche numero. 


punto di vista grafico, presenta un 
sommario organizzato in rubriche, 
che riporta: 

• Gaming Sins: how multi-pla- 
tform releases hurt thè PC 
games industry. 

• Review: Dream Web 

• Li sten Up! 2D or not 2D 

• The Underground: Betasup- 
pe 

• Honour. Fallout VS Fallout 3 


Speriamo che Abandoned Times 
possa proseguire e costituire un 
interessante archivio di recensio¬ 
ni, interviste, prove varie dei titoli 
che hanno appassionato moltis¬ 
sime persone negli anni dal 90 in 
poi. 

La piattaforma PC, come tutti gli 
appassionati sanno, ha vissuto fra 
il 1990 e il 2000 un’epoca d’oro 
per quanto riguarda le uscite di 
titoli di intrattenimento. In quegli 
anni le console rimasero un po’ al 
palo e i vecchi home mostrarono 
il fiato corto rispetto alle crescen¬ 
ti esigenze di coinvolgimento da 
parte del giocatore incallito, ma 
anche occasionale. 

Ci sono stati dei titoli vere “killer 
applications” rispetto alla piattafor¬ 
ma. Mi viene in mente ad esempio 
“Flight Simulator” di Microsoft o 
“Doom”, tanto per citare due gio¬ 
chi che tutti conoscono, ma ovvia¬ 
mente la lista sarebbe lunghissi¬ 
ma. 

Venendo alla fanzine, “Aban¬ 
doned Times” per ora ha solo 12 
pagine, coloratissime e curate dal 


• Re vie w: Mech Warrior 

• Loving Memory: Commander 
Keen 


In conclusione, una rivista com¬ 
pletamente free che è piacevole 
da leggere e che rivela molte cose 
sui vecchi titoli per PC. 

[L2] 


La home page del 
sito Abandonia. 
Spartano ed essen¬ 
ziale. 



site nm'tjalion \ leaiured carne \ forum 


latestiiews 


sutscnbel 



boxshots: montezuma's return 

Emuli Scanaboxshot, daring advencurer and rumoured descsndant of thè 
legendary Baxshot erri pero', must dscover thè secrets of a lost civilisation 
while stranOed on an undiarfed Online island. As thè plot unrolds by 
scanning a series of five Boxshots and so claiming all eye-treasutes ot thè 
box, he restones thè desecrated tomb of his legendary ancestor thereb» 
lifting thè curseof thè ESA. 


posteti by luthsen,, 29-07-2009 U box sbots /, pemalink 



extras & boxshots 

Today we celebrate a great gem from thè éghties! 

Take a look at boxshots & manuals for A rkanoid II: Revenge of Doh , 
one of thè Dest ‘ball and paddle’ games ever made. 

Special thanks go to one of our Best contributo^ ever 1 Apoiause to 

Geezer' 


posteC by Dave 1 28-07-2009 U dcmnloadaDle game /, Arcane 
permalink 



copy protcction codes: network q rac rally 

To pretend that we also take care of and even remove old deficiencies, I 
deieted thè NetHack key manual that was connected to Network Q RAC 
Rally Championship as itscopy protecdon codes, typed up thè more or 
less reai ones, and - of course - added them to thè site. Along thè way, I 
changed thè game's title to thè correct Network Q RAC Rally (little 
game series confusion, you know). 


A non-alcohoiic drink goes out to johnny d who misused thè post report 
funclon to , remintf’ us of this now remeded nuisance. 


This reminds me to say that you shojld teli us atout mistakes and 
missing codes at thè game’s discussion thread; not because I fear a wave 


userMine: paworfl: 

[ logln< 

not a irember yetf resister bere! fonjot yDur password? reset here! 




[ Sardi ) 1 + English 


abandonia daily screenshal 
qui:: _ 



quiclì mais 

timi 

Tefal; I1M 
DavnloaóaSle: 1056 
Stxigs: 1520 
Excras: 922 
«smbere 
Tefal; 110334 





H5LP Pie 


fPLÌStj 



^Inrigidal 
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SAP Corner 



SAPNetWeaver 7.0 Trial Ed. 


Una nuova rubrica 
dedicata ad un 
ambiente non retro 
che ospitiamo in 
esclusiva per l’Italia 


Menu Edit Favorites Extras System Help 

c l, ceg> affina eopa sa ®i 

SAP Easy Access 





NSP(1)(000) 0 sapnw-big OVR 


|UFj (LJj |òQ menu | |«ej| iqj |\ \ ^ 1|— | |Uf mio \ , ' 1 




uucumtMiicuiuii i 


a Favorites 

0 SLICENSE - Adminlsler SAP Llcenses 

Gl SAP menu 
t> □ Office 

l> □ Cross-Applicallon Componente 
I> □ Information Systems 
^ Gl Tools 




l> □ ABAPWorkbench 
0 □ Customizing 


□ Administration 

□ ALE 

□ Business Communication 

□ Business Framework 

□ Business Workllow 

□ CCMS 

0 SXDA-Data Transfer Workbench 
0 EEWB-Easy Enhancement Workbench 

□ Web Development 

□ Form Printout 

□ Hypertext 

□ Find 


SAP NetWeaver™7.0 

ABAP Trial Version 

Copyright © ^002-^006 SAP AG All Rights Reserved 




Figura 1. 
L'interfaccia. 


T utti i software si evolvono, 
così accade anche per 
l’ambiente ERP per eccel¬ 
lenza: cioè per SAP. 

Dopo aver lavorato sulla “vecchia” 
4.6, è venuto il momento di aggior¬ 
nare la nostra installazione, tanto 
per tenersi allineati con le novità. 

Abbiamo scaricato la nuova ver¬ 
sione del trial dal sito “educational” 
di SAP via registrazione gratuita. I 
due file .RAR di circa 1,2 Gb ca¬ 
dauno vanno scompattati per ave¬ 
re un’unica directory di installazio¬ 
ne contenente tutto l’occorrente 
(2,8 Gb circa). 

L’installazione è simile a quella 
che abbiamo già intrapreso per la 


versione precedente: si parte con 
la pagina html che riporta le infor¬ 
mazioni principali e il link per far 
partire effettivamente il program¬ 
ma di Setup (figura 2). 

Per quanto non strettamente ne¬ 
cessario, è bene disinstallare la 
precedente versione, altrimenti si 
potrebbero verificare delle interfe¬ 
renze nel registry della macchina 
(informazione comunque riportata 
in dettaglio nella documentazione 
di installazione). 

Dal punto di vista tecnologico la 
versione 7.0 è molto diversa dalla 
4.6 con la quale abbiamo mosso 
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ABAP Trial Vorsion Lcorninq Vatcnai 
Starting Irom thè AGAR worfcbench. you will ftnd 
sample programa and tutonals tnat showcase 
Ui dovdoomom witri ì/vgd DynproforABAP. 

Links to SDN and tho omino documontation ioad 
to funhor inTormaiion rogardmg ABAP doi/oiopmcnt. 


inai Vorsion 


Ccoondna « 
irsrallng SA 


Configurimi database. This step maytake up to 2 hours. 


Atlfualinq 


cantei 


Ccnsob bro-vse to <n*ML/pifa>\s<Vinmr and execute sapmmcXBfknTwj 
It s highlv reccmmonded to restart yter System after nstallation. 


Errar handling 


If your nstdlation tcrmlnatcs belerei! issucccsstully ccrrrdcted. obasc i 
irtscaBer . in seme cases it E reiessary to remo/e eisung regEtry ertnes 
(sflpstaitsrv.esc) befote storting thè ristaiti agnn If 111? pittato peisst* 


the nstdlcd Hcs ond icKort fctac 




r.hr.kthe fngbj 


NW 200*15 ABAP Trial Version Microsolt Internet Explorer 


SAP Netweawer 7.0 ABAP Trial Versior 


i ReqUienerti 


talhtaon 
:ttaj ftaited 
nstdl 


/ primi passi nell’ambiente ABAP. Si 
può schematizzare l’evoluzione nella 
tabella riportata più sotto. 

Il bello dell’ambiente SAP è che no¬ 
nostante l’evoluzione tecnologica e 
funzionale, l’intero ERP rimane co¬ 
erente con se stesso e i vecchi pro¬ 
grammi continuano a “girare” con al li¬ 
mite pochi aggiustamenti da ricercare 
fra l’utilizzo di oggetti complessi che 
magari, nella nuova versione, hanno 
avuto in dono un parametro in più. 


e ;Doojrercs‘,' 0 zjand% 


OABAPT rialSP J 2/COC/htm|h-Etcllatlons. 


0 Back • o a n © p*** iz* 

A l I—, [fficifooorrem | 


e m & 


Business 


•) My Computer 


Figura 2. 


Figura 3. 


SAP R/3 4.0 

mySAP ERP 6.0 

NetWeaver SOA 

Client-server 

Web Application 

Server 

S0A Bus - Web Services 


My Corrpjt» 5 ARIW7. OA.. 


Anche ABAP, il linguaggio di pro¬ 
grammazione “storico” di SAP, è ri¬ 
masto pressoché invariato mentre ad 
esso si è affiancato (già dalla versione 
6) il più moderno (o “alla moda”) dava. 
Come abbiamo già avuto modo di ri¬ 
levare nelle puntate del corso pubbli¬ 
cate su Jurassic News, in effetti pochi 
usano dava e solo se i loro progetti 
necessitano di oggetti e librerie “esoti¬ 
che” difficilmente riproducibili nell’am¬ 
biente ABAP. 



: * 


SAP Front End Installer 

Installino Componente 

Pleass «vait \vtnle SAPSslup processe* the Configuri 


■ 0« 


i ofthe selected SAP Produci*. 


0 win DOWBtsyste m 3 2im sd atgrd c 






L’installazione, rispettate le poche re¬ 
gole elencate nei requisiti di sistema, 
non presenta intoppi e prosegue senza 
difficoltà. L’unica “sorpresa”, se così si 
può dire, è la constatazione che al ter¬ 
mine del processo di setup, l’ambiente 
va ad occupare qualcosa più di venti 
giga. Da tenerne conto se si inten¬ 
de installare in una macchina virtua¬ 
le. Un’altra idiosincrasia è il fatto che 
l’installazione della GUI, cioè la parte 
Clientdell’ambiente (figura 4), deve es¬ 
sere lanciata dopo aver copiato la cor- 



Figura 4. 


► 


Choose thè connection type and change the System parameteis as required. Leave the description 
lield empty if you want thè System to piopose a description. Buttons 'Next >' and 'Finish' are only active 
when all requited input data has been enteied. 


Connection Type: Custom Application Server ■ 



FI Use this page as the First page lor next entiy cieations. This is eltective immediately 
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SAP 

Managem... 


0 

Start 

Applicati... 


Figura 5. 


rispondente 
directory 
dal DVD di 
installazio¬ 
ne al file 
System (ad 
esempio sulla scrivania) del com¬ 
puter ospite. E’strana questa cosa 
e non ho mai capito se questo suc¬ 
cede solo a me, visto che altri tec¬ 
nici cui ho rivolto la domanda non 
mi hanno dato importanza, come 
se stessi dicendo una stupidaggi¬ 
ne. Comunque sia, siete avvisati: 
se il setup della GUI vi da un erro¬ 
re di protezione, copiate la directo¬ 
ry sul disco e partite da li. 

Assieme al server e alla GUI 
Client, è possibile (e direi consi¬ 
gliato), caricare le utility di gestio¬ 
ne del database (Figura 3). 

Al termine ci si ritrova con quattro 
icone sul desktop (figura 5) 

Si hanno a disposizione i seguen¬ 
ti programmi: SAP Management 
Console, Start Application Server, 
SAP Logon e Tweak SAP GUI. 


Per far partire il servizio si deve 
lanciare Start Application Server 
che si presenta come una conso¬ 
le DOS (figura 7). Questa console 
può essere anche chiusa, contra¬ 
riamente alle versioni precedenti 
dell’ambiente Trial che richiedeva¬ 
no di lasciarla in esecuzione. 

A Questo punto va configurata 
la connessione al server (si tratta, 
ricordiamo di un ambiente client- 
server). Attraverso ‘‘SAP Logon” 
deve essere impostato l'indirizzo 
di rete e i parametri del server da 
raggiungere (figura 4) 

Per configurare i parametri (colo¬ 
ri, font,..) della GUI la SAP ha mes¬ 
so a disposizione un configuratore 
(Tweak SAP GUI) (figura 6) 

Al momento del LOG IN al siste¬ 
ma si possono scegliere tre diversi 
utenti, differenziati per ruolo: SAP * 
è un utente amministratore, così 
come DDIC (ricoprono utilizzi di¬ 
versi) e il “classico” BCUSER che 
è l’account di sviluppatore. Tutti e 
tre hanno come password “mini- 
sap” (Figura 7). 


SAP Logon 


Tweak SAP GUI 


Figura 6. 



I Or. 11 Apply | | Revert | 


Un programmatore SAP che pro¬ 
venga da una release precedente 
dell’ambiente workbench si ritrova 
famigliarmente con gli stessi stru¬ 
menti, menù e tools delle prece¬ 
denti versioni. In realtà esistono 
minime differenze, soprattutto esi¬ 
stono tool aggiuntivi che rendono 
ancora più completa la dotazione 
degli strumneti disponibili al co- 
der. 
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Quello che ha subito un opportu¬ 
no svecchiamento è l’editor (figura 
8), adattato ora molto meglio alle 
moderne tecniche di codifica. 

Scrittura, check e attivazione del 
codice si svolge esattamente nella 
forma consueta (Figura 9). 


Client 

[OGO 

Information / 




SAP NetWeaver 7.0 ABAP Trial Vtersion 

User 

BCUSER 




Password 

************ 

Login information: 




Client 

User 

Password 

Language 

m 

000 

SAP* 

minisap 



000 

DDIC 

minisap 



000 

BCUSER 

minisap 


Figura 7. 


Conclusione. 

Un plauso alla SAP AG che con¬ 
tinua con lo stesso entusiasmo e 
con la stessa caparbietà a fornire 
un ambiente educational/test per 
avvicinare sempre più persone al 
proprio sistema ERP. Certo la cri¬ 
si economica sta colpendo anche 
questa azienda, che recentemente 
ha annunciato un piano di tagli pre¬ 
occupante, ma in ogni caso rimane 
ben salda al top dei sistemi infor¬ 
mativi aziendali nel mondo. 


[Mx] 


Nota della redazione 

Sono pochissime le occasioni per 
sentire parlare di SAP dal punto di 
vista del programmatore in Italia. 
Abbiamo colto l’occasione di cono¬ 
scenza di una persona che lavora 
nel campo come consulente free 
lance per curare prima il corso di 
ABAP (terminato da poco) ed ora 
per lancirare una vera rubrica fissa 
dedicata al sistema leader di mer¬ 
cato nell’informatica gestionale. 



I Program £dil goto Utilities Enyironment System Help 


ABAP Editor: Change Report ZTN_TEST_01 _ 

□ @ @ IH] fij| I @|Tj^)|§| 'HyÈH CIIH ESIftlI Pattern || Pretty Printer | 
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Apple Club 


La mela come 
paradigma della 
programmazione 


Il linguaggio PL 
in una particolare 
implementazione 
sponsorizzata dalla 
rivista Bit. 


Tutti i linguaggi dell ’Apple (12) 


PL✓BIT COMPÌLER 02.2 
URITTEN BY 
CARLO MACHAGHI 


SOURCE TEXT 


Il linguaggio PL/Bit 

D omanda: -'Ma se il lin¬ 
guaggio che sto cercan¬ 
do non è disponibile per 
il mio calcolatore?” 

-"Nessun problema: se manca un 
compilatore basta costruirselo!”. 

Certo che questa affermazione 
mette la parola fine alla ricerca del¬ 
la disponibilità del linguaggio del 
quale abbiamo proprio bisogno. Per 
contropartita è anche abbastanza 
inquietante, dal momento che chi 
conosce di programmazione sa 
benissimo che non è proprio una 
passeggiata costruirsi un interpre¬ 
te e peggio ancora un compilatore. 
Passi per un macro-assembler che 


tutto sommato è una traduzione 
uno a uno fra istruzione e codice 
binario, ma un “vero” linguaggio ad 
alto livello, magari strutturato? 

Prima di tutto è naturale chiedersi 
che necessità ci sia di disporre pro¬ 
prio di quel particolare interprete o 
compilatore quando è noto a tut¬ 
ti che tutti i linguaggi formali sono 
equivalenti. Il che significa in paro¬ 
le povere che si può implementare 
un algoritmo in qualunque linguag¬ 
gio di programmazione purché suf¬ 
ficientemente completo. 

La risposta è che una macchina 
come l’Apple II è usata molto per il 
settore educational, cioè per quelle 
attività di insegnamento dell’infor¬ 
matica e della programmazione dei 
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calcolatori. Se disponiamo di una 
descrizione teorica di un linguag¬ 
gio di programmazione, cosa che 
succede ad esempio sul libro di 
Nikolaus Wirth “Algorithms + Data 
structures = Programs”, ci piace¬ 
rebbe averne una implementazio¬ 
ne pratica con la quale sperimen¬ 
tarne le caratteristiche. 

Preso atto di questa considera¬ 
zione e constatato che nel volume 
citato esiste la descrizione formale 
del linguaggio di programmazio¬ 
ne chiamato PU1, un certo Carlo 
Magnaghi ha deciso di costruirse¬ 
ne una implementazione che gira 
sull’Apple Ile sotto DOS. La de¬ 
scrizione del suo lavoro è appar¬ 
sa su i fascicoli di programmazio¬ 
ne allegati alla rivista Bit e che si 
chiamava “Bit Riservato Personal” 
nell’anno 1984 (precisamente sui 
fascicoli numerati 52, 53 e 54). 

L’articolo è necessariamente mol¬ 
to lungo, comprendendo tutti i sor¬ 
genti del compilatore: un sorgente 
BASIC di circa 500 Statement più 
un listato assembler, oltre che tutte 
le spiegazioni del caso e tre sor¬ 
genti in PL/Bit come test ed esem¬ 
pio delle capacità del linguaggio e 
del compilatore in se e per se. 

Davvero è da rendere omaggio 
all’autore perché è un lavoro accu¬ 
rato, per nulla semplice e di gran¬ 
de spessore tecnico! 

Messe da parte le doverose lodi 
al merito, passiamo a descrivere il 
prodotto. 

Partendo da un sorgente di testo 


PL/BIT COMPÌLER U2.2 
NRITTEN BY 
CARLO MAGNAGHI 


SOURCE TEXT HILBERT 
OBJECT TEXT HILBERT.0 
OBJECT CODE STARTS AT 4000 
STACK STARTS AT 8000 
SHAPE TO LOAD 

INTERFACE 


che contiene il codice da compila¬ 
re, il programma in Applesoft (esi- „ ., 

' Il compilatore in 

ste anche in versione compilata azione dopo aver 
con TASC), crea il codice oggetto chiesto il nome del file 

e produce infine l’eseguibile con sorgente e i parametri 

., ... .. ... .. , .. di compilazione 

I ausilio di una libreria di funzioni 

standard a corredo del compilato¬ 
re stesso. 

Al termine della compilazione il 
file binario prodotto è eseguibile 

Il compilatore non 

con il consueto comando BRUN pwduce direttamente 
del sistema operativo DOS 3.3. Veseguibile ma un 

. , .. ... sorgente assembler che 

Non ci sembra il caso di dilun- , . , 

deve poi a sua volta 

garci nell esame di come sia CO- essere assemblato per 
struito questo compilatore che, lo generare il vero file 

ripetiamo, è un eccellente esem- binario pronto per 

.. . rv xx ^ l’esecuzione, 

pio di programmazione. Piuttosto 


'LlST 

UHAT TEXT 

TYPE ; 

CONTROL- 


ANY KEY 

STA 

TOS 

LDY 

#0 

LDA 

< 136), Y 

STA 

LSD + 0 

INY 


LDA 

< 136), Y 

STA 

MSD+0 

INC 

TOS 

LDA 

#0 

STA 

MSD+1 

LDA 

#0 

STA 

LSD+1 

INC 

TOS 

•JSR 

GT. 

LDA 

MSD 

ORA 

LSD 

BNE 

LBL.0 


TO STOP LISTINO 
TO CONTINUE 
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,<Y*3>/2; 

COLL E: I -1 ; 

END 
END ; 

BEGIN IT : =0 ; 

REPEAT IT : =1-IT; 

DALL SHOWPAGE 1 ; DALL USEPAGE 1; 

DALL FILLSCREEH 0;CALL HCOLOR 3; 

I :=0;H = =H0;X0 = = H/2 j Y0 = =X0 ; 

REPEAT 

IF IT=0 THEN DALL FILLSCREEN 0; 

I : = I +1 ; H : = H ■■■" 2 j 
X 0 : = X 0 + H / 2 ; Y 0 : = Y 0+H / 2 ; 

X : =X0+28;Y : =Y0; DALL HPLOT <X*3>/2,<Y*3 
)/2; 

DALL A I; 

UNTIL I=N 
UNTIL 1=2 
END. 

***** 0 ERRORS FLAGGED 


facciamo un giro nel linguaggio PL 
Nessun errore di e nella sua implementazione “ca- 

compilazione: bene! sareccia ” PUBit. 


Purtroppo non possiamo allegare 
il PDF della serie di articoli, perché 
coperti da copyrights, per cui vi do¬ 
vete accontentare di un sommario 
overview del sottoscritto sulle prin¬ 
cipali caratteristiche del linguag¬ 
gio. 

Partiamo con leggere un sorgente 
di esempio. Si tratta del program¬ 
ma Queen, abbastanza famoso e 
che consiste nel trovare le posizio¬ 
ni di otto regine sulla scacchiera in 
modo che non siano mutualmente 
minacciate. 


Nel box listato 1 l’intero sorgen¬ 
te. Così a prima vista noterete che 
praticamente è Pascal, del resto 
il Wirth è proprio l’ideatore del lin¬ 
guaggio Pascal e questo PU1 è 
evidentemente uno studio prelimi¬ 
nare al linguaggio che poi l’ha reso 
popolare nel mondo. 

L’assegnazione del valore ad una 
variabile tramite l’operatore di¬ 
rei che è proprio la firma di Wirth 



che era un purista ossessionato 
dalla semantica dei linguaggi for¬ 
mali. 

Si parte con la dichiarazione delle 
variabili globali. Il linguaggio tratta 
solo variabili intere e quindi non 
c’è alcuna necessità di dichiararne 
il tipo. Quello che segue ARRAY 
sono dichiarazioni di vettori con i 
rispettivi limiti inferiore e superio¬ 
re. 

Un programma PL è composto da 
un corpo e da eventuali procedure 
che sono richiamate all’interno del¬ 
le istruzioni. Il programma Queen 
comincia con l’istruzione BEGIN 
in fondo alla pagina e termina con 
END seguito dal punto. Il punto “. ”, 
come in Pascal, determina la fine 
del sorgente. 

Le due subroutine, chiamate ri¬ 
spettivamente TRY e PRINT si 
chiamano reciprocamente e ricor¬ 
sivamente, nel senso che TRY 
chiama la PRINT quando ha biso¬ 
gno di mandare in output un risul¬ 
tato e la TRY chiama se stessa per 
iterare la ricerca delle soluzioni. 

Una cosa strana e che salta im¬ 
mediatamente all’occhio è la pre¬ 
senza di istruzioni precedute dal 
simbolo chiocchiola e che in 
pratica è un codice assembler in¬ 
line. 

Ad esempio nella procedura 
PRINT serve per chiamare le rou¬ 
tine di output sul video contenute 
nel firmware dell’Apple Ile. Mentre 
l’istruzione in-line 

@ JSR $FD8B 
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VARI; 

ARRAY 

Al. .8, 
B 2..16, 
C-7..7, 
X 1..8; 
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Listato 1. 

Il sorgente del 
programma Queen. 


PROCEDURE PRINT; 

VAR K.NUMOUT; 

BEGIN 

K:=0; 

REPEAT 

K:=K+1; 

NUMOUT:=X(K); 
@ LDA LSD 
@ JSR $FDE3 
@ JSR $F948 
UNTIL K=8; 

@ JSR $FD8B 

END; 


PROCEDURE TRY I; 

VAR J; 

BEGIN 

J:=0; 

REPEAT 

J:=J+1; 

IF A(J) AND B(I+J) AND C(I-J) THEN 
BEGIN 

X(I):=J; 

A(J):=0; 

B(I+J):=0; 

C(I-J):=0; 

IF I<8 THEN 

CALL TRY 1+1 

ELSE 

CALL PRINT; 
A(J):=1; 

B(I+J):=1; 

C(I-J):=1 

END 

UNTIL J=8 

END; 


BEGIN 

I:=0; 

@ JSR $FD8B 
REPEAT 

I:=I+1; 
A(I):=1 
UNTIL 1=8; 

CALLTRY 1 


END. 
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trova nel 


corpo del 
sorgente 
principale, 
serve per 
pulire il vi¬ 
deo. 


La stra 


La macchina, bontà 
sua, sta sputando fuori 
le soluzioni del gioco 
delle otto regine. I 
numeri si riferiscono 
alla posizione della 
regina nelle rispettive 
righe. Ad esempio la 
prima soluzione: 1, 5, 
8, 6, 3, 7, 2, 4 significa 
che nella prima 
colonna la regina è 
nella casella 1, nella 
seconda colonna 
c'è una regina nella 
posizione 5 e così via. 


da seguita 

dall’autore del compilatore è stata 
quella di focalizzarsi sulla tradu¬ 
zione delle istruzioni proprie del 
linguaggio usando quello che è di¬ 
sponibile per l’I/O già implementa¬ 
to nella macchina. 


Un pochino più articolato il sor¬ 
gente HANOI (box listato 2) che 
risolve la famosa torre di Hanoi, 
altro tormentone da studenti di in¬ 
formatica primo anno. 


In questo caso si parte con la 
dichiarazione INTERFACE che 
in pratica dichiara cosa vogliamo 
usare come output e, lo si capisce 
dalle direttive che seguono la di¬ 
chiarazione, stiamo lavorando con 
la pagina semigrafica 1 dell’Apple. 


All’interno del sorgente nota¬ 
te le macro come CALL HPLOT, 
HPLOTTO, etc... di chiaro signifi¬ 
cato. In questo sorgente c’è anche 
la dichiarazione di costante (state¬ 
ment CONST) dichiarata all’inizio 
prima delle variabili. La sequenza 
delle dichiarazioni è rigida: prima 
le costanti, poi le variabili semplici 
e poi gli array. Del resto si tratta di 
limitazioni più che accettabili. 
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Vediamo come le procedure pos¬ 
sono ricevere parametri come 
nella MOVEDISK che riceve due 
coordinate: ORG e DST, eviden¬ 
temente con significato di origine 
e destinazione. Ricordiamo che il 
“gioco” consiste nello spostare dei 
dischi di dimensione variabile da 
un piolo iniziale al piolo finale uti¬ 
lizzando al più un piolo intermedio 
con il vincolo di non appoggiare 
mai un disco su uno di diametro 
inferiore. 


Usare il compilatore 

Sul dischetto distribuito con il 
compilatore esistono due versioni: 
il sorgente Applesoft classico e il 
compilato via TASO che richiede 
però la presenza del RUNTIME 
per essere eseguito. 

Devo dire che la differenza di 
esecuzione è abbastanza limita¬ 
ta fra le due versioni, almeno sui 
sorgenti corti come quelli di esem¬ 
pio. Se si vuole usare l’interprete si 
lancia con RUN PL/BIT, se si desi¬ 
dera usare il compilato si può usa¬ 
re il file di comandi che risiede sul 
dischetto con nome COMPILER e 
va fatto partire con 

EXEC COMPILER 

questo carica la libreria TASO 
e poi l’eseguibile che si chiama 
PL.OBJ 

In ogni caso il compilatore chiede 
il nome del file sorgente, il nome 
dell’oggetto da produrre, l’indirizzo 
di memoria (in decimale) dove si 
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INTERFACE 
USEPAGE 1, 
SHOWPAGE 1, 
FILLSCREEN 1, 
HCOLOR1, 
HPLOT 2, 
HPLOTTO 2; 


Listato 2. 

Il sorgente del 
programma Hanoi. 


CONST YMOVE=140; 


VAR 

ARRAY 


XMID 1 ..20, 
WIDTH 1 ..20, 
YLOW 1 ..20; 


NUM,IJ; 


PROCEDURE MOVEDISK ORGJDST; 

VAR XO,YO,XD,YD,X 1 ,X2,XM,I,DISK,D; 

BEGIN 

XO:=ORG*90+50; 

XD:=DST*90+50; 

YO:=200; 

YD:=190; 

I:=0; 

REPEAT 

I:=I+1; 

IF YLOW(I)<YO AND XMID(I)=XO THEN 
BEGIN 

YO:=YLOW(I); 

DISK:=I 

END; 

IF YLOW(I)<YD AND XMID(I)=XD THEN 
YD:=YLOW(I) 

UNTIL I=NUM; 

YD:=YD-5; 

XM:=XMID(DISK); 

X1 : =XM-WIDTH( DISK) ; 
X2:=XM+WIDTH(DISK); 

REPEAT 

CALL HCOLOR 0; 

CALL HPLOT XI ,YO; 

CALL HPLOTTO X2,YO; 

CALL HCOLOR 3; 

CALL HPLOT XI ,YO-4; 

CALL HPLOTTO X2,YO-4; 

YO:=YO-l 

UNTIL YO<YMOVE; 

D:=2*(DST>ORG)-l; 
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PL/BIT COMPÌLER 02.2 
WRITTEN BY 
CARLO MAGNAGHI 


SOURCE TEXT HILBERT 
OBJECT TEXT HILBERT.0 
OBJECT CODE STARTS AT 4000 
STACK STARTS AT 8000 
SHAPE TO LOAD 


INTERFACE 


Si comincia la 
compilazione del 
programma Hilbert. 


vuole par¬ 
ta il codice 
e l’indiriz¬ 
zo dello 
stack (vie¬ 
ne consi¬ 
gliato per 

10 stack 

11 valore 
2048). 

Durante 
la compi¬ 
lazione, che avviene in un’unica 
passata, il compilatore stampa le 
righe di sorgente che sono di volta 
in volta tradotte. Sembrerebbe una 
perdita di tempo e nessun compila¬ 
tore oggi si sognerebbe mai di pro¬ 
porre questa opzione, ma invece 
per le macchine “antiche” questo 
era utile: si capiva che il lavoro an¬ 
dava avanti e si identificava imme¬ 
diatamente la riga con l’eventuale 
errore bloccante. 


Per quanto riguarda la velocità di 
traduzione da sorgente a codice 
oggetto non è nulla di paragona¬ 
bile ad un Turbo Pascal, tanto per 
fare confronti non troppo distanti. 

Prima di tutto già la preparazio¬ 
ne dell’esecuzione (caricamento 
libreria TASO e oggetto PL.OBJ), 
impiega buoni quaranta secondi 
prima di presentare la domanda 
del nome del sorgente da compi¬ 
lare. 

Un sorgente come HILBERT di 
circa un centinaio di statement, 
impiega due minuti e trentacinque 
secondi su un Apple Ile a 1 MHz, 
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per arrivare alla fine. 

Che volete farci: si lancia e si va a 
prendere il caffè, un classico! 

Il codice sorgente così ottenu¬ 
to consiste in un file di testo con 
l’elenco delle istruzioni mnemoni¬ 
che sono da assemblare con un 
assemblatore standard (non pre¬ 
sente sul dischetto del compilato¬ 
re). 


Assemblare il tutto 


Noi abbiamo deciso di usare l’as¬ 
semblatore ED ASM che è presen¬ 
te sul dischetto “Utility Disk” assie¬ 
me al DOS 3.3 quando si compra 
un Apple. Per prima cosa prepa¬ 
riamo un dischetto di lavoro che 
contenga tutto quello che serve. 
Noi lo abbiamo fatto partendo da 
un floppy vuoto e caricandoci tutti 
i programmi indispensabili per l’in¬ 
tera sessione. 

Per quanto riguarda il compilato¬ 
re PL/BIT, ammesso di voler usare 
la versione non compilata, serve 
solamente il programma Applesoft 
PL/BIT. 

Abbiamo messo sul floppy anche 
il programma GET TEXT che ser¬ 
ve per farsi stampare a video un 
file di testo, il programma EDITOR 
(sempre trovato sul dischetto utility 
del DOS) per editare i sorgenti. 

Per l’assemblatore serve il pro¬ 
gramma ED ASM, la sua parte 
compilata che si chiama ASM.OBJ 
e un file del quale non abbiamo 
capito lo scopo ma che se non è 










presente manda in dump l’assem¬ 
blatore: ASMIDSTAMP 

Serve inoltre la libreria PL chiama¬ 
ta RUNTIME che viene assemblata 
assieme al file oggetto per produrre 
il compilato eseguibile. 

La fase di assemblaggio prevede 
di invocare il programma assem¬ 
bler: 

RUN EDASM 

e quindi al prompt dello stesso (il 
carattere due punti) digitare il co¬ 
mando: 

ASM SIER 

(Nota: SIER è il nome del file object 
ottenuto dalla compilazione del sor¬ 
gente Sierpinsky). 

L’assemblatore produce sul di¬ 
schetto il file con nome SIER.OBJO 
che è appunto l’eseguibile. L’esecu¬ 
zione del programma compilato non 
richiede runtime e si ottiene con il 
semplice comando BRUN: 

BRUN SIER.OBJO 


Data la scarsa reperibilità di questo 
software abbiamo deciso di allegare 
il dischetto a questo numero della 
rivista. Prima di fare ciò abbiamo 
cercato inutilmente di rintracciare 
il sigron Magnaghi per chiedere il 
permesso. Purtroppo non ci siamo 
riusciti, così confidiamo di non 
fargli cosa sgradita permettendo 
a tanti appasssionati della Mela ai 
quali magari a suo tempo era sfug¬ 
gito il suo lavoro di farlo rivivere. 
Potete scaricare V immagine del 
floppy da 140 Kb formato DSK dal 
sito della rivista. 
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1 

<C> COPYRIGHT 

1979 


APPLE COMPUTER 

INC 


: ASM SIER 



PRESS ANY KEY T0 CONTINUE 
SOURCE FILE: SIER. 




Conclusione 


Qui è in funzione 
I ’assembler 


Aldilà dell’effettiva utilità pratica 
del compilatore PL/Bit, non possia¬ 
mo che constatare con non poca 
soddisfazione come il sistema della 
Apple si presentava adatto alla ste¬ 
sura di codice anche di media com¬ 
plessità. Giocava sicuramente a fa¬ 
vore una conoscenza “intima” della 
macchina e delle sue potenzialità 
che era disponibile a coloro che si 
potevano dedicare anima e corpo e 
soprattutto che avevano tempo per 
esplorarne le potenzialità. 

[Sm] 


Ed ecco il programma 
Sierpinsky in 
esecuzione. 
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